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VORWORT 


Das vorliegende Buch enthält eine ausführliche Beschreibung der Assembler¬ 
sprache des Mikroprozessors 6502. Es enthält zahlreiche Programmierbeispie¬ 
le, vom einfachen Laden eines Speichers bis zu vollständigen Entwicklungs¬ 
projekten 

Das Schwergewicht liegt auf einer großen Anzahl von völlig fehlerfreien, prakti¬ 
schen Programmierbeispielen im Standard-Format, einschließlich Flußdia¬ 
gramm, Quellprogramm, Objektcode und erläuterndem Text, 

Ferner ist jeder Befehl des 6502 detailliert erklärt, wie auch die Assembler-Ver¬ 
einbarungen für den 6502, Ebenso werden Eingabe/Ausgabe-Operationen mit 
dem peripheren Interface Adapter 6520 (PIA), dem Versatile Interface Adapter 
6522 (VIA), den Mehrfunktions-Bausteinen 6530 und 6532 sowie dem asynchro¬ 
nen Kommunikations-Interface Baustein 6850 behandelt. 

Ausführliche Besprechungen für die Erstellung von Programmen, von der Defini¬ 
tion der Aufgabe uberTesten, Fehlersuche, Dokumentation bis hin zu modularer 
und strukturierter Programmierung runden dieses Werk ab. 
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Kapitel 1 

EINFÜHRUNG IN DIE 
ASSEMBLER-PROGRAMMIERUNG 


Dieses Buch beschreibt die Programmierung in Assemblersprache. Es wird an¬ 
genommen, daß Sie mit dem Buch "Einführung in die Mikrocomputer- 
Technik" (insbesondere Kapitel 6) vertraut sind. Im vorliegenden Buch werden 
die allgemeinen Eigenschaften von Computern, Mikrocomputern, Adressier¬ 
verfahren oder Befehlssätzen nicht besprochen. Alle diese Fragen wirden in 
der bereits erwähnten "Einführung in die Mikrocomputer-Technik” erörtert. 

WIE DIESES BUCH GEDRUCKT IST 

Es ist zu beachten, daß dieses Buch mit fetten und mageren Buchstaben ge¬ 
druckt ist. Dies hilft jene Teile des Buches zu überspringen, deren Inhalt viel¬ 
leicht bekannt ist. Man kann sicher sein, daß der mager gedruckte Teil nur 
jene Informationen ausführlich behandelt, die im vorausgehenden fettgedruck¬ 
ten Teil bereits dargestellt wurden. Man braucht daher nur den fettgedruckten 
Teil zu lesen, bis man ein Thema erreicht, über das man mehr zu wissen 
wünscht und kann von hier ab mit dem Lesen des mager gedruckten Teiles be¬ 
ginnen. 

DIE BEDEUTUNG VON BEFEHLEN 

Der Befehlssatz eines Mikroprozessors besteht aus einem Satz von binären 
Eingangssignalen, mit denen bestimmte Tätigkeiten während eines Befehls- 
Zyklus bewirkt werden. Ein Befehlssatz ist für einen Mikroprozessor das gleiche 
wie eine Funktionstabelle für einen Logik-Baustein, wie etwa ein Gatter, Addie¬ 
rer oder Schieberegister, Natürlich sind die Tätigkeiten, die ein Mikroprozessor 
infolge eines Befehles ausführt, wesentlich komplexer als jene Tätigkeiten, die 
ein Logik-Baustein infolge seiner Eingangssignale durchführt. 

Ein Befehl ist ein binäres Bitmuster - es muß an den 
Dateneingängen des Mikro-prozessors zur richtigen Zeit 
anliegen, um als Befehl interpretiert zu werden. Wenn bei¬ 
spielsweise der Mikroprozessor 6502 das aus 8 Bits bestehende Binärmuster 
1 101000 als Eingabe während eines Befehlsabrufes empfängt, so bedeutet 
dieses: 

"Inkrementiere (addiere 1) zum Inhalt von Register X", 

Ahnlich bedeutet das Muster 1 fl 01001: 

"Lade den Akkumulator mit dem Inhalt des nächsten Wortes des Pro¬ 
grammspeichers" 

Der Mikroprozessor (wie auch jeder andere Computer) erkennt nur binäre Mu¬ 
ster als Befehle oder Daten. Er ist nicht imstande, Worte oder Oktal, Dezimal- 
der Hexadezimalzahlen zu erkennen. 
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EIN COMPUTERPROGRAMM 

Ein Programm besteht aus einer Sehe von Befehlen, die den Computer zur 
Ausführung einer bestimmten Aufgabe veranlassen. 


In Wirklichkeit enthält ein Computerprogramm mehr als Be¬ 
fehle Es enthält auch Daten und Speicheradressen, die der 
Mikroprozessor zur Ausführung der durch die Befehle defi¬ 
nierten Aufgaben benötigt Zweifellos muß der Mikroprozessor zur Ausführung 
einer Addition hierfür zwei Zahlen besitzen, sowie einen Platz, in den er das 
Resullat ablegt Das Computerprogramm muß die Quellen der Daten und 
den Bestimmungsort für das Resultat bestimmen und muß ferner die auszufuh- 
rende Operation angeben. 

Die meisten Mikroprozessoren führen Befehle sequentiell aus, es sei denn, einer 
der Befehle ändert die Befehlssequenz oder hält den Computer an. Das heißt, 
der Prozessor erhält den nächsten Befehl von der nächsthöheren Speichera¬ 
dresse, außer der momentane Befehl weist ihn an. etwas anderes auszuführen. 

Jedes Programm wird letztlich in einen Satz von Binärzahlen umgewandelt. 
Folgendes ist beispielsweise ein Programm für den 6502, das den Inhalt der 
Speicherplätze 0060i S und 0061 1E addiert und das Ergebnis in den Speicher¬ 
platz 0062is ablegt: 


COMPUTER¬ 

PROGRAMM 


10100101 
01 1 00000 
01 100101 
01100001 
10000101 
01100010 


Dies ist ein Maschinensprachen- oder Objekt-Programm. 

Wenn dieses Programm in einen auf einem 6502 basieren¬ 
den Mikrocomputer eingegeben wird, so ist der Mikrocom¬ 
puter imstande, dieses Programm direkt auszuführen 


DIE PROBLEME DES PROGRAMIERENS 

Es gibt verschiedene Schwierigkeiten, die mit der Bildung von Programmen in 

Form eines Objektprogrammes, d.h. eines Programmes in binärer Maschinen¬ 
sprache, verbunden sind. Einige dieser Probleme sind: 

1) Die Programme sind schwierig zu verstehen oder fehlerfrei zu machen 
(Binärzahlen sehen einander sehr ähnlich, insbesondere wenn man be¬ 
reits einige Stunden mit ihnen gearbeitet hat). 

2) Die Eingabe der Programme ist sehr langwieng, da man jedes Bit individuell 
bestimmen muß. 

3) Die Programme beschreiben die Aufgabe , die der Computer ausführen soll, 
nicht in irgendeinem vergleichbaren vom Menschen lesbaren Format, 

4) Die Programme sind lang und mühsam zu schreiben. 

5) Der Programmierer macht häufig Fehler, die sehr schwer zu finden sind 


OBJEKT¬ 

PROGRAMM 


MASCHINEN¬ 

SPRACHEN¬ 

PROGRAMM 


Die folgende Version unseres Additions-Objektprogrammes enthält beispiels¬ 
weise ein einziges vertauschtes Bit. Versuchen Sie es zu finden: 

10100101 
01100000 
01110101 
01100001 
10000101 
01 100010 

wohl der Computer Binärzahlen mit Leichtigkeit handhabt, ist dies für einen 
enschen sehr schwierig. Der Mensch findet Binärprogramme lang, mühsam, 
wirrend und bedeutungslos. Ein Programmierer könnte sich mögli- 
erweise einige der Binärcodes merken, aber derartige Anstrengungen sollten 
oduktiver verwendet werden. 

VERWENDUNG VON OKTAL-ODER HEXADEZIMALZAHLEN 

Wir können diese Situation wesentlich verbes¬ 
sern, indem wir die Befehle in Form von Oktal¬ 
oder Hexadezimal-, anstatt von Binärzahlen zu 
schreiben. Wir werden in diesem Buch Hexadezimalzahlen verwenden, da sie 
ku'zer sind und bereits zum Standard für die Mikroprozessor-Industrie gewor¬ 
den sind. Tabelle 1-1 definiert die Hexadezimalziffern und ihre binären Äquiva¬ 
lente Das Programm für den 6502 zur Addition zweier Zahlen sieht nun folgen¬ 
dermaßen aus: 

A5 

60 

65 

61 

85 

62 

Man sieht, daß die hexadezimale Version wesentlich kürzer in der Schreibwei¬ 
se ist und lange nicht so ermüdend bei der Überprüfung. 

Fehler sind wesentlich leichter in einer Folge von Hexadezimalziffern zu fin¬ 
den. Die fehlerhafte Version unseres Additionsprogramms sieht nixi in hexade¬ 
zimaler Form folgendermaßen aus: 

A5 

60 

75 

61 

85 

62 

Der Fehler ist wesentlich einfacher zu erkennen. 

Was fangen wir aber nun mit diesem hexadezimalen Programm an? Der Mikro¬ 
prozessor versteht nur binäre Befehlscodes. Die Antwort ist, daß wir die Hexa- 
d«-: malzahlen in Binärzahlen umwandeln müssen. Diese Umwandlung ist 
eine sich wiederholende mühsame Aufgabe. Bei dieser Umwandlung macht 
man im allgemeinen alle möglichen Arten der schönsten Fehler, wie etwa das 
Ve wechseln einer Zeile, Vergessen eines Bits, oder Vertauschen ei¬ 
nes Bits oder einer Stelle. 


OKTAL- ODER HEXA¬ 
DEZIMALZAHLEN 
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Diese sich wiederholende und zermürbende Arbeit ist je- HEXADEZIMAL* 
doch eine ideale Aufgabe für einen Computer Der Compu LADER 
ter wird niemals müde oder gelangweilt und macht niemals 
leichtfertige Fehler. 

Es liegt daher nahe, ein Programm zu schreiben, das die hexadezimalen 
Zahlen aufnimmt, sie in Binärzahlen umwandelt und die Binärzahlen in den 
Speicher des Mikrocomputers bringt. Dies ist ein Standardprogramm, das für 
viele Mikroprozessoren erhältlich ist. Es wird Hexadezimal-Lader genannt. 

Lohnt sich ein Hexadezimal-Lader? Wenn man die Absicht hat, ein Programm 
unter Verwendung von Binarzahlen zu schreiben, und wir bereit sind, das Pro¬ 
gramm in seiner binären Form in den Computer einzugeben, dann werden wir 
keinen Hexadezimal-Lader benötigen. Wenn wir einen Hexadezimal-Lader wäh¬ 
len, so müssen wir einen Preis hierfür zahlen Der Hexadezimal-Lader ist selbst 
ein Programm, das man in den Speicher laden muß. Außerdem wird der Hexa- 
dezimal-Ladei Speicherplatz besetzen - Speicherplatz, den wir vielleicht lüi 
andere Zwecke benötigen würden. 

Die Vorteile des Hexadezimal-Laders liegen, abgesehen von den Kosten und 
den Speicher-Anforderungen in der Einsparung der Programmierzeit. 

Ein Hexadezimal-Lader ist daher seine geringen Kosten wert 

Ein Hexadezimal-Lader löst aber keinesfalls irgendein Programmierproblem. 
Die hexadezimale Version des Programmes ist noch immer schwierig zu lesen 
und zu verstehen Er unterscheidet beispielsweise weder Befehle von Daten 
oder Adressen, noch ergibt sich aus der Auflistung des Programmes irgen¬ 
dein Hinweis darauf, was das Programm ausführt Was bedeutet 86 oder DO? 
Das Auswendiglernen einer langen Reihe von Codes ist sicherlich nicht sehr 
attraktiv Ferner unterscheiden sich die Codes völlig bei unterschiedlichen 
Mikroprozessoren, und das Programm benötigt eine umfangreiche Dokumenta¬ 
tion. 


Tabelle 1-1. Hexadezimai-Umwandlungstabelle 


Hexadezimal¬ 

ziffer 

Binäres 

Äquivalent 

Dezimales 

Äquivalent 

0 

0000 

0 

1 

0001 

1 

2 

0010 

2 

3 

0011 

3 

4 

0100 

4 

5 

0101 

5 

6 

0110 

6 

7 

0111 

7 

8 

1000 

8 

9 

1001 

9 

A 

1010 

10 

B 

1011 

11 

C 

1100 

12 

D 

1101 

13 

E 

1110 

14 

F 

1111 

15 
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MNEMONIKS FÜR BEFEHLSCODES 


Eine offensichtliche Verbesserung des Programmierens stellt die Zuweisung 
einer Bezeichnung zu jedem Befehlscode dar. Den Namen eines Befehlscodes 
nennt man ein "Mnemonik”, oder mnemotechnisches Hilfsmittel. Die mnemo¬ 
technische Abkürzung eines Befehls sollte in irgendeiner Form beschreiben, 
was der Befehl ausführt. 


In der Tat liefert leder Hersteller eines Mikroprozessors PROBLEME 

en Satz von Mnemomks für den Befehlssatz seines Mi- MIT 

oprozessors. Man muß sich jedoch nicht mit dem Be- MNEMONIKS 
fehlssatz des Herstellers abfinden. Sie sind jedoch Stan- 
ard für einen gegebenen Mikroprozessor und werden daher von allen Anwen- 
ern verstanden Daher stellen sie die Bezeichnungen lür die Befehle dar, die 
man in Handbüchern, Listen, Büchern. Arikeln und Programmen findet. Das 
Problem bei der Auswahl von Mnemoniks für Befehle besteht darin, daß nicht 
alle Befehle "offensichtliche" Namen besitzen. Bei einigen Befehlen ist dies der 
all (z.B ADD, AND, OR), andere bestehen aus oftensichtlichen Abkürzungen 
(z B. SUB für Subtraktion, XOR für Exklusiv-ODER), während dies bei anderen 
überhaupt nicht der Fall ist. Daraus resultieren Mnemoniks wie etwa WMP, 
PCHL und auch SOB (versuchen Sie ihre Bedeutung zu erraten!). Die meisten 
ersteller verwenden einige brauchbare Namen, zum Teil aber auch sehr un- 
g'uckliche Bezeichnungen. Anwender, sie sich ihre eigenen Mnemoniks aus¬ 
denken, werden wahrscheinlich kaum bessere Bezeichnungen als der Hersteller 
fnden. 

Zusammen mit den Befehls-Mnemoniks wird ein Hersteller gewöhnlich auch den 
CPU-Registern entsprechende Namen zuweisen. Ebenso wie bei den Befehls- 
ramen besitzen einige Register offensichtliche Bezeichnungen (z.B. A für 
Akkumulator) während andere mehr historische Bedeutung besitzen. Wir Wollen 
doch wiederum die Vorschläge der Hersteller verwenden, einfach um eine 
Slandardisierung zu fördern 

Wenn wir die Standard-Mnemoniks für Befehle und Regi- PROGRAMM IN 
ster des 6502 verwenden, wie sie von der Firma MOS ASSEMBLER- 
T chnology definiert wurden, so wird unser Additionspro- SPRACHE 
gramm für den 6502 folgendermaßen aussehen: 


D‘e Darstellung des Programms ist immer noch nicht völlig offensichtlich, aber 
es werden wenigstens einige Teile hiervon verständlich. ADC ist eine beträchtli¬ 
che Verbesserung gegenüber 65. LDA und STA lassen auf Laden (Loading) und 
Speichern (Storing) schließen. Wir wissen nun, welche Zeilen Befeh- 
le sind und welche Daten oder Adressen. Ein derartiges Programm stellt ein 
Programm in Assemblersprache dar. 


DAS ASSEMBLERPROGRAMM 

W e bekommen wir nun das Programm in dasProgramm in 
Assemblersprache in den Computer? Wir müssen es über¬ 
setzen, entweder in Hexadezimal- oder Binärzahlen. 


HAND- 

ASSEMBLIE¬ 

RUNG 
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Man kann ein Programm in Assemblersprache manuell übersetzen, Befehl für 
Befehl. Dies wird Hand-Assemblierung genannt. Hand-Assemblierung einer aus 
drei Befehlen bestehende Folge ist nachstehend gezeigt. 


Befehls-Mnemonik 

Adressier-Art 

Hexadezimales Äquivalent 

LDA 

Null-Seite (direkt) 

A5 

ADC 

Null-Seite (direkt) 

65 

STA 

Null-Seite (direkt) 

85 


Wie im Falle der Umwandlung hexadezimal in binär, ist die Hand-Assemblierung 
eine Routine-Aufgabe, die uninteressant, sich wiederholend und anfällig für 
zahllose kleine Irrtümer ist. Veiwenden der falschen Zeile. Vertauschen von Zif¬ 
fern, Auslassen von Befehlen und falsches Lesen der Codes sind nur einige der 
Fehler, die einem unterlaufen können. Die meisten Mikroprozessoren machen 
die Aufgaben noch komplizierter, indem sie verschieden Befehle mit unter¬ 
schiedlichen Wortlängen besitzen. Manche Befehle sind nur ein Wort lang, wäh¬ 
rend andere eine Länge von zwei oder drei Worten besitzen. Manche Befehle 
benötigen Daten im zweiten und dritten Wort. Andere benötigen Speicheradres¬ 
sen, Registernummern oder andere Informationen. 


Die Assemblierung ist eine weiter routinemäßige Aufgabe, 
die wir einem Mikrocomputer überlassen können. Der Mi¬ 
krocomputer macht niemals Fehler beim Übersetzen von 
Codes. Er weiß immer, wieviele Worte und welches For¬ 
mat jeder Befehl benötigt. Ein Programm, das eine derarti¬ 
ge Aufgabe ausführt, wird Assembler genannt. Das 
Das Assemblerprogramm übersetzt ein Anwenderpro¬ 
gramm oder Quellenprogramm (auch als Quellprogramm 
bezeichnet), das mit Mnemoniks geschrieben wurde, in ein Programm in Ma¬ 
schinensprache (oder Objektprogramm) , das der Mikrocomputer ausführen 
kann. Die Eingabe für den Assembler Ist ein Quellenprogramm und er gibt ein 
Objektprogramm aus. (Bei der Benützung des Wortes "Assembler’’ ist jeweils 
darauf zu achten, ob nun die Assembler-Sprache oder das Assembler¬ 
programm gemeint ist). 

Die Überlegungen, die wir beim Hexadezimal-Lader angestellt haben, gelten in 
erhöhtem Maße für den Assembler). Assembler sind aufwendiger, benötigen 
mehr Speicherplatz und erfordern längere Ausführungszeilen als Hexadezimal 
Lader. Während Anwender häufig ihre eigenen Lader schreiben, geschieht dies 
weniger häufig als bei Assemblern. 

Assembler besitzen eigene Regeln, die man erlernen muß. Diese enthalten die 
Verwendung bestimmter Markierungen oder Kennzeichen (wie Zwischenräume, 
Kommata, Strichpunkte oder Doppelpunkte) an den entsprechenden Stellen, 
korrekte Aussprache, die richtige Steuer Information und vielleicht auch die ord¬ 
nungsgemäße Plazierung von Namen und Zahlen Diese Regeln sind gewöhn¬ 
lich einfach und können rasch erlernt werden. 


ZUSÄTZLICHE EIGENSCHAFTEN VON ASSEMBLERN 

Frühere Assembler-Programme leisteten wenig mehr als die Übersetzung der 

Mnemoniks der Befehle und Register in ihr binäres Äquivalent. Die meisten 

neueren Assemblerprogramme besitzen zusätzliche Eigenschaften, wie 

1) Sie gestatten dem Anwender die Zuweisung von Namen zu Speicherplätzen, 
Eingabe- und Ausgabe-Bausteinen und sogar vollständigen Befehls-Se¬ 
quenzen 

i) Die Umwandlung von Daten oder Adressen von verschiedenen Zahlensyste¬ 
men (z B. dezimal oder hexadezimal) in binäre und die Umwandlung von Zei¬ 
chen in ihre ASCII- oder EBCDIC Binärcodes, 

3) Die Ausführung einiger anthmetischer Operationen als Teil des Assemblier- 
Vorganges 

4) Die Mitteilung an das Ladeprogramm, wohin Teile des Programmes oder Da¬ 
ten in den Speicher plaziert werden sollen. 

Sie gestatten dem Anwender die Zuweisung von Speicherbereichen für zeit¬ 
weilige Datenspeicherung und die Plazierung fester Daten in bestimmte Be¬ 
reiche des Programmspeichers, 

6 ) Die Lieferung von Informationen, die für Standardprogramme aus einer Pro- 
gramm-Bibliothek erforderlich sind, oder für Programme die zu einer anderen 
Zeit geschrieben wurden, für das momentane Programm. 

7) Sie gestatten dem Anwender die Steuerung des Formats der Programm-Auf¬ 
listung und der verwendeten Eingabe und Ausgabe-Bausteine. 


Ile diese Eigenschaften bedingen natürlich zusätzliche 
osten und Speicher. Mikrocomputer haben im allgemei- 
en wesentlich einfachere Assembler als große Computer, 
ndieren jedoch immer größer zu werden. Man besitzt häu- 
g eine Auswahl an verschiedenen Assembler-Programmen. Das wichtigste Kri- 
num hierbei ist nicht, wieviele ausgefallene Eigenschaften der Assembler be- 
tzt, sondern wie bequem er bei der Anwendung in der Praxis ist 


NACHTEILE DER ASSEMBLERSPRACHE 

Der Assembler, ebenso wie der Hexadezimal-Lader, löst keinesfalls die ge¬ 
samten Probleme des Programmierens. Ein Problem besteht in der gewaltigen 
Lucke zwischen dem Befehlssatz des Mikrocomputers und den Aufgaben, die 
der Mikrocomputer auszuführen hat. Computerbefehle führen meist Dinge aus, 
wie das Addieren des Inhalts zweier Register, Verschieben des Inhalts des 
Akkumulators um ein Bit, oder das Plazieren eines neuen Wertes in den Be- 
fehlszählei. Auf der anderen Seite möchte ein Anwender eines Mikrocomputers 
etwa die Prüfung, ob eine analoge Ablesung einen bestimmten Wert überschrit¬ 
ten hat. nach einem bestimmten Kommando eines Fernschreibers Ausschau 
halten und auf dieses zu reagieren, oder ein Relais zur richtigen Zeil aktivieren. 
Ein Programmierer, der die Assemblersprache verwendet, muß derartige Aufga¬ 
ben in eine Folge (oder Sequenz) einfacher Computerbefehle umwandeln. Diese 
Umwandlung kann eine schwierige und zeitraubende Aulgabe darstellen. 

Ferner muß man beim Programmieren in Assemblersprache eine sehr detail- 
erte Kenntnis des verwendeten speziellen Mikrocomputers besitzen. Man 

uß wissen, welche Register und Befehle der Mikrocomputer hat. wie die Beteh- 
die verschiedenen Register genau beeinflussen, welche Adressier-Verfahren 
er Computer verwendet und eine Unmenge weiterer Informationen. Keine die- 
er Informationen ist für die Aufgabe, die der Mikrocomputer letztlich ausführen 
muß, relevant. 


ASSEMBLER 


QUELLEN¬ 

PROGRAMM 


OBJEKT¬ 

PROGRAMM 


AUSWAHL 

EINES 

ASSEMBLERS 
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Programme in Assemblersprache sind nicht übertragbar. 

Jeder Mikrocomputer besitzt seine eigene Assemblerspra¬ 
che, die duich seine Architektur bestimmt wird. Ein Pro¬ 
gramm in Assemblersprache, das für den 6502 geschrieben wurde, wird nicht 
auf dem 6800, dem 280. 8080 oder dem 3870 laufen Unser Additionsprogramm 
würde beispielsweise für den 8080 folgendermaßen lauten: 


LDA 

60H 

MOV 

B.A 

LDA 

61H 

ADD 

B 

STA 

62H 


VORTEILE VON HÖHEREN PROGRAMMIERSPRACHEN 

Offensichtlich erleichtern höhere Sprachen das Programmieren und beschleu¬ 
nigen die Erstellung eines Programmes. Man kann etwa sagen, daß ein Pro¬ 
grammierer ein Programm zehnmal schneller in einer höheren Sprache als 
in der Assemblersprache schreiben kann. Dies betrifft nur das Schreiben des 

Programms Es enthält nicht die Definition der Aufgabe, Entwicklung des Pro¬ 
gramms, Fehlersuche, Testen oder Dokumentation, das ebenfalls einfacher 
und schneller wird. Das Programm in der höheren Sprache ersetzt beispielswei¬ 
se zum Ten eine entsprechende Dokumentation. Sogar wenn man FORTRAN 
nicht beherrscht, kann man wahrscheinlich erkennen, was die oben darge¬ 
stellten Anweisungen besagen. 


ÜBERTRAG¬ 

BARKEIT 


Da die Programme nicht übertragbar sind, bedeutet dies, daß wir unser Pro¬ 
gramm in Assemblersprache nicht auf einem anderen Mikrocomputer verwen¬ 
den können. Das bedeutet auch weiter, daß wir nicht imstande sind, irgendein 
Programm zu verwenden, das nicht für unseren Mikrocomputer speziell ge¬ 
schrieben wurde. Dies ist ein Nachteil für Mikrocomputer, da diese Bausteine 
neu sind und noch nicht allzu viele Programme in Assemblersprache existieren 
Daraus ergibt sich häufig, daß man auf sich selbst angewiesen ist Wenn man 
ein Programm für die Ausführung einer speziellen Aufgabe benötigt, wird 
man dies wahrscheinlich nicht in den kleinen Programm-Bibliotheken der Her¬ 
steller finden. Man wird es auch wahrscheinlich kaum in einem Archiv, Zeitungs¬ 
artikel oder einer alten Programm-Bibliothek finden. Wahrscheinlich muß man 
sich sein Programm selbst schreiben. 


KOMPILIERER 


HÖHERE PROGRAMMIERSPRACHEN 

Die Lösung für viele der mit Assemblersprachen-Program- 
men verbundenen Schwierigkeiten ist die Verwendung von 
"höheren” oder "probtem-orientieiten" Sprachen. Derartige Sprachen gestat¬ 
ten die Beschreibung von Aufgaben in einer Art und Weise, die eher problem- 
orientieit als computer-orientiert ist. Jede Anweisung in einer höheren Pro¬ 
grammiersprache führt eine erkennbare Funktion aus. Sie wird im allgemeinen 
mehreren Befehlen in Assemblersprache entsprechen. Ein Programm, das 
Kompilierer (oder Compiler) genannt wird, übersetzt ein Quellenprogramm 
höheren Programmiersprache in Befehle in Objektcode oder Maschinen¬ 
sprache. 


FORTRAN 


Es existieren mehrere unterschiedliche höhere Sprachen 
für verschiedene Arten von Aufgaben. Wenn wir beispiels¬ 
weise die Aufgabe für unseren Computer in einer algebraischen Darstellung 
ausdrücken können, so können wir unser Programm in FORTRAN (FORmula 
TRANslation language) schreiben, der ältesten und am meisten verbreiteten 
höheren Programmiersprache. Wenn wir nun zwei Zahlen addieren wollen, so 
müssen wir dem Computer nur sagen: 


SUM= NUMB1 +NUMB2 


Dies ist um einiges einfacher (und auch kürzer) als irgendein äquivalentes Pro¬ 
gramm in Maschinensprache oder ein äquivalentes Programm in Assembler¬ 
sprache. Andere höhere Programmiersprachen sind COBOL (für kaufmännische 
Anwendungen), ALGOL und PASCAL (andere algebraische Sprachen), PL/1 
(eine Kombination von FORTRAN, ALGOL und COBOL) und APL und BASIC 
(Sprachen fürTime-Sharing-Systeme und Hobby-Computer) 


Höhere Sprachen lösen viele andere Probleme, die mit der 
Programmierung in Assemblersprache verknüpft sind. Die 

höhere Sprache besitzt ihre eigene Syntax (gewöhnlich de¬ 
finiert durch einen nationalen oder internationalen Stan¬ 
dard). In der Sprache werden Befehlssatz, die Register oder 
andere Eigenschften eines speziellen Computers nicht er¬ 
wähnt. Auf alle derartige Details muß der Compiler achten. 

Die Programmierer können sich auf ihre eigentliche Aufgabe konzentrieren. Sie 
brauchen die verwendete CPU-Architektur nicht im Detail zu verstehen, das 
heißt, sie brauchen nicht einmal etwas über den Computer zu wissen den sie 
programmieren. 


Programme, die in einer höheren Sprache geschrieben 
wurden, sind übertragbar; zumindest in der Theorie. Sie 

werden auf jedem beliebigen Computer laufen, der einen 
Standard-Kompilierer für diese Sprache besitzt. Dadurch 
sind aber alle früher in einer höheren Sprache geschrie¬ 
benen Programme für bestimmte Computer auch verfügbar, wenn man einen 
neuen Computer programmieren will. Dies kann im Falle der gebräuchlichsten 
Sprachen wie FORTRAN oder BASIC bedeuten, daß man tausende von Pro¬ 
grammen zur Verfügung hat. 


NACHTEILE VON HÖHEREN PROGRAMMIERSPRACHEN 

Wenn nun aber alle erwähnten Vorteile, die wir bei höheren Programmierspra¬ 
chen aufgezählt haben, wahr sind, wenn man Programme schneller schreiben 
kann und sie außerdem übertragbar sind, warum qq,ält man sich dann über¬ 
haupt noch mit Assembler-Sprachen? Wer würde sich noch mit Registern, Be¬ 
fehlscodes, Mnemoniks und all diesem Ballast herumschlagen? Wie gewöhn¬ 
lich steht allen Vorteilen meist auch eine entsprechende Anzahl von Nachtei¬ 
len gegenüber. 


Ein offensichtliches Problem liegt darin, daß man die 
"Regeln" oder die "Syntax" jeder höheren Programmier¬ 
sprache, die man verwenden will, lernen muß. Eine höhere 
Sprache besitzt einen ziemlich komplizierteren Satz von 
Regeln. 


SYNTAX VON 

HÖHEREN 

SPRACHEN 


ÜBERTRAGBAR¬ 
KEIT VON 
HÖHEREN 
SPRACHEN 


MASCHINEN¬ 
UNABHÄNGIG¬ 
KEIT VON 
HÖHEREN 
PROGRAMMIER¬ 
SPRACHEN 
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Man wird finden, daß man viel Zeit benötigt, ein Programm zu erhallen, das syn¬ 
taktisch korrekt ist (und sogar dann wird es wahrscheinlich noch nicht das tun, 
was man will). Eine höhere Computersprache ist wie eine Fremdsprache. Wenn 
man ein wenig Talent besitzt, wird man steh rasch mit den Regeln vertraut ma¬ 
chen, und imstande sein, Programme zu liefern, die der Kompilierer annimmt 
Aber mit dem Lernen der Regeln und dem Versuch, das Programm für den 
Kompilierer annehmbar zu machen, ist unsere Aufgabe noch lange nicht gelöst 

Einige FORTRAN-Regeln sehen etwa folgendermaßen aus: 

Marken (Labels) müssen gänzlich aus Zahlen bestehen und in die er¬ 
sten fünf Kartenspalten plaziert werden 
Anweisungen müssen h Spalte sieben beginnen 
Ganzzahlige Variable müssen mit dem Buchstaben I, J, K, L. M oder N 
beginnen 

Ein weiteres Problem liegt darin, daß man einen Kompilie- KOSTEN VON 
rer zur Übersetzung der in einer höheren Sprache ge- KOMPILIERERN 
schriebenen Programme in Maschinensprache benötigt. 

Kompilierer sind aufwendig und benötigen große Speicher. Während die mei¬ 
sten Assembler von 2K bis 16 K Bytes eines Speichers belegen (1K = 1024), 
benötigt ein Kompilierer gewöhnlich wesentlich mehr Speicherplatz. Daher lie¬ 
gen die Kosten bei der Verwendung eines Kompilierers wesentlich höher. 

Ferner machen nicht alle Kompilierer unsere Aufgabe tat- ALGEBRAISCHE 
sächlich leichter. FORTRAN ist beispielsweise sehr gut für SCHREIBWEISE 
Aufgaben geeignet, die man als algebraische Formeln 
darstellen kann Wenn wir jedoch die Aufgabehaben, einen Drucker zu steuern, 
eine Kette von Zeichen zu editieren oder ein Alarmsystem zu überwa¬ 
chen, kann unsere Aufgabe nicht ohne weiteres in algebraischer Schreibweise 
dargestellt werden. In der Tat kann die Formulierung der Lösung in algebrai¬ 
scher Schreibweise wesentlich mühsamer und schwieriger sein, als ihre Formu¬ 
lierung in Assemblersprache. Die naheliegende Antwort wäre natürlich die 
Verwendung einer besser geeigneten höheren Sprache. Es existieren einige 
derartige Sprachen, aber sie sind weit weniger verbreitet und standardisiert wie 
FORTRAN. Man wird nicht all zu viel von den Vorteilen höherer Sprachen haben, 
wenn man diese sogenannten "System-Implementation-Languages" (etwa- 
System-Durchführungs-Sprachen) verwendet. 

Höhere Sprachen ergeben häufig wenig effiziente Pro- INEFFIZIENZ 
gramme in Maschinensprache. Der wesentliche Grund hier- HÖHERER 
für ist, daß die Kompilierung einen automatischen Vorgang SPRACHEN 

darstellt, der voll mit Kompromissen für die Ausführung - 

zahlreicher Möglichkeiten ist. Der Kompilierer arbeitet ahn- OPTIMIERENDE 
lieh einem computergesteuerten Sprach-Übersetzer, bei KOMPILIERER 
dem die Worte manchmal stimmen, aber der Klang und der 
Satzbau wirkt äußerst unbeholfen. Ein einfacher Kompilierer 
kann nicht wissen, wann eine Variable nicht länger verwendet wird und gelöscht 
werden kann, wann ein Register besser anstelle eines Speicherplatzes verwen¬ 
det werden soll, oder wann Vanable einfache Beziehungen untereinander besit¬ 
zen. Der erfahrene Programmierer kann die Vorteile von Abkürzungen verwen¬ 
den. um die Ausführungszeit zu verringern oder die Verwendung des Speichers 
zu reduzieren. Einige wenige Kompilierer (bekannt als optimierende Kompilie¬ 
rer) können dies ebenfalls, aber derartige Kompilierer sind wesentlich größer 
und langsamer als gewöhnliche Kompilierer 
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Oie allgemeinen Vorteile und Nachteile höherer Programmiersprachen sind: 

Voiteile: 

• Bequemer für die Beschreibung von Aufgaben VORTEILE 

• Größere Produktivität des Programmierers HÖHERER 

• Einfachere Dokumentation SPRACHEN 

• Standardisierte Syntax - 

• Unabhängigkeit von der Struktur eines speziellen Computers 

• Übertragbarkeit 

• Verfügbarkeit von Bibliotheken und anderen Programmen 
Nachteile: 

• Spezielle Regeln 

• Weitgehende Flardware- und Software-Unterstüt- NACHTEILE 

zung erforderlich HÖHERER 

• Onentierung der gebräuchlichen Sprachen auf al- SPRACHEN 

gebraische oder kaufmännische Probleme - 

• Ineffiziente Programme 

• Schwierigkeiten bei der Optimierung des Codes für zeitliche und Spei¬ 
cher-Anforderungen 

• Unmöglichkeit der bequemen Verwendung spezieller Eigenschaften 
eines Computers 


HÖHERE SPRACHEN FÜR MIKROPROZESSOREN 

Die Anwender von Mikroprozessoren werden auf verschiedene spezielle 
Schwierigkeiten stoßen, wenn sie höhere Programmiersprachen verwenden. 
Diese sind unter anderem: 

• Es existieren wenige höhere Programmiersprachen für Mikroprozessoren. 

• Es sind keine Standardsprachen allgemein verfügbar. 

• Wenige Kompilierer laufen tatsächlich auf Mikrocomputern. Die es tun, be¬ 
nötigen oft sehr großen Speicherraum. 

• Die meisten Mikroprozessor-Anwendungen sind nicht besonders gut für 
höhere Programmiersprachen geeignet. 

• Speicherkosten sind häufig in Mikroprozessor-Anwendungen kritisch. 

Das Fehlen höherer Programmiersprachen liegt zum Teil in der Tatsache be¬ 
gründet, daß Mikroprozessoren verhältnismäßig neu sind, und Produkte der 
Hersteller von Halbleitern sind, anstelle von Computer-Herstellern. Es existieren 
sehr wenige höhere Sprachen für Mikroprozessoren. Die bekanntesten hiervon 
sind die Sprachen wie BASIC 4 , PASCAL 5 , FORTRAN und die PL/I-Sprachen, 
wie PL/M 6 , MPLund PLpS. 

Weil nun die wenigen existierenden höheren Sprachen nicht anerkannten Stan¬ 
dards entsprechen, kann der Mikroprozessor-Anwender nicht erwarten, daß vie¬ 
le Programme übertragbar sind, er Zugriff zu Programm-Bibliotheken erhält, 
oder frühere Erfahrungen oder Programme verwenden kann. Die verbleibenden 
Hauptvorteile liegen daher in der Verringerung des Programmier-Aufwandes 
und des geringeren erforderlichen detaillierten Verständnisses der Computer- 
Architektur 
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Die mit der Verwendung höherer Programmiersprachen 
bei Mikroprozessoren verbundenen Kosten sind beträcht¬ 
lich. Mikroprozessoren sind für Steuerungen und andere 
Anwendungen besser geeignet als für Zeichen-Manipula¬ 
tionen und Sprach-Analysen bei der Kompilierung Daher 
werden die meisten Kompilierer für Mikroprozessoren nicht aut einem System 
laufen, das auf einem Mikroprozessor basiert. Sie erfordern stattdessen einen 
wesentlich größeren Computer, das heißt, sie sind eher Cross-Kompilierer 
(Kompilierer, der nicht auf dem Mikrocomputer läuft, für den das zu kompilieren¬ 
de Programm geschrieben ist) anstatt Selbst-Kompilierer. Ein Anwender muß 
daher nicht nur die Aufwendungen für den größeren Computer tragen, er muß 
auch das Programm physikalisch vom großen Computer zum Mikrocomputer 
übertragen 

Es sind einige wenige Selbst-Kompilierer verfügbar Diese Kompilierer laufen 
auf dem Mikrocomputer, für den sie den Objektcode erzeugen. Unglücklicher¬ 
weise benötigen sie jedoch sehr viel Speicherplatz (16K oder mehr), sowie spe¬ 
zielle unterstützende Hardware und Software. 


Höhere Programmiersprachen sind auch im allgemeinen für 
Mikroprozessor-Anwendungen nicht gut geeignet. Die mei¬ 
sten der bekannten Sprachen sind entweder zur Lösung 
wissenschaftlicher Probleme oder für die Handhabung 
großer Datenmengen in der kommerziellen Datenverarbei 
tung vorgesehen. Wenige Mikroprozessor-Anwendungen fallen in diese Berei¬ 
che. Die meisten Mikroprozessor-Anwendungen beinhalten das Senden von Da¬ 
ten und Steuer-Informationen zu Ausgabe Bausteinen und das Empfangen von 
Daten und Status-Informationen von Eingabe-Bausteinen. Häufig bestehen die 
Steuer- und Status-Informationen aus einigen wenigen binären Ziffern mit sehr 
genauen Bedeutungen bezüglich der Hardware. Wenn man versuchen würde, 
ein typisches Steuerprogramm in einer höheren Sprache zu schreiben, würde 
man sich häufig so fühlen, als ob man versuchen würde, eine Suppe mit Stäb¬ 
chen zu essen. Für Aufgaben wie etwa Testgeräte, Terminals, Navigahonssyste- 
me und Bürogeräte arbeiten die höheren Sprachen wesentlich besser als dies 
bei Anwendungen in der Instrumentation, Kommunikation, Steuerung von pen- 
pheren Bausteine und im Automobil der Fall wäre. 


Besser geeignete Anwendungen für höhere Sprachen sind 
jene, in denen große Speicher erforderlich sind. Wenn die 
Kosten eines einzelnen Speicherchips wesentlich sind, wie 
dies zum Beispiel in einem Steuergerät, elektronischen 
Spiel, Haushaltsgerät oder einem kleineren Instrument der 
Fall ist, dann ist die Ineffizienz der höheren Sprache nicht mehr tragbar Wenn 
andererseits das System mehrere tausend Bytes eines Speichers besitzt, wie 
dies in einem Terminal oder Testgerät der Fall ist, dann ist die Ineffizienz der hö¬ 
heren Sprachen nicht so wesentlich. Natürlich sind die Größe des Programmes 
und die produzierte Stückzahl des betreffenden Gerätes ebenfalls wesentliche 
Faktoren. Ein großes Programm wird die Vorteile der höheren Sprachen ent¬ 
sprechend nutzen Andererseits werden bei einer Anwendung mit hoben Stück¬ 
zahlen die festen Software-Entwicklungskosten nicht so wesentlich sein, wie die 
Speicherkosten, die ein Teil jedes Systems sind. 


ANWENDUNGS¬ 

BEREICHE 

für 

HÖHERE 

SPRACHEN 


UNZWECK¬ 

MÄSSIGKEIT 

HÖHERER 

SPRACHEN 


KOSTEN 

FÜR 

HÖHERE 

SPRACHEN 


WELCHES NIVEAU SOLLTE MAN VERWENDEN? 

Dies hängt von der speziellen Anwendung ab. Es sollen kurz die Faktoren zu 
sammengefaßt werden, die für ein spezielles Programmier-Niveau den Aus¬ 
schlag geben: 


Maschinensprache 

• Ein Programm in Maschinensprache ist tatsäch¬ 
lich völlig unwirtschaftlich und schwierig zu doku¬ 
mentieren. Ein Assembler kostet wenig und ver¬ 
ringert die Programmierzeit außerordentlich. 


Assemblersprache: 

• Kleine bis mittlere Programme 

■ Anwendungen, bei denen die Speicherkosten ein 

wesentlicher Faktor sind 

• Echtzeit-Steueranwendungen 

• Begrenzte Datenverarbeitung 

• Anwendungen mit hohen Stückzahlen 

• Anwendungen, in denen mehr Eingaben/Ausga¬ 
ben oder Steuerungen als Berechnungen Vorkom¬ 
men. 


Höhere Sprachen 

• Lange Programme 

• Anwendungen mit kleiner Stückzahl, die jedoch 
lange Programme benötigen 

• Anwendungen, die bereits große Speicher erfordern 

• Anwendungen, in denen mehr Berechnungen als Eingaben/Ausgaben 
oder Steuerungen Vorkommen 

• Kombatibilität mit ähnlichen Anwendungen, die größere Computer 
verwenden 

• Verfügbarkeit von speziellen Programmen in höherer Sprache, die in 
der vorliegenden Anwendung verwendet werden können 


ANWENDUN¬ 
GEN FÜR 
MASCHINEN¬ 
SPRACHE 


ANWENDUN¬ 
GEN FÜR 
ASSEMBLER¬ 
SPRACHE 


ANWENDUN¬ 
GEN FÜR 
HÖHERE 
SPRACHEN 


Viele andere Faktoren sind ebenfalls wichtig, wie etwa die Verfügbarkeit eines 
größeren Computers für die Entwicklung, Erfahrung mit speziellen Sprachen und 
Kompatibilität mit anderen Anwendungen. 

Wenn schließlich die Hardware die wesentlichsten Kosten in unserer Anwen¬ 
dung darstellt, oder die Geschwindigkeit kritisch ist, sollte auf jeden Fall die As¬ 
semblersprache bevorzugt werden. Man muß jedoch damit rechnen, daß man 
zusätzliche Zeit für die Entwicklung der Software aufwenden muß, um dafür 
niedrigere Speicherkosten und höherer Ausführungsgeschwindigkeit zu erhal¬ 
ten. Wenn die Software die größten Kosten in unserer Anwendung darstellen, so 
sollte man höhere Sprachen bevorzugen Aber es sind zusätzliche Kosten für 
die Hilfs-Hardware und Software erforderlich. 

Natürlich ist auch die Verwendung sowohl der Assemblersprache als auch hö¬ 
herer Programmiersprachen möglich. Man kann das Programm zunächst in ei¬ 
ner höheren Sprache schreiben und dann einzelne Abschnitte durch Assembler¬ 
sprache ersetzten. 7 Es wird dies jedoch in der Praxis nicht häufig durchgeführt, 
da hierdurch gewaltige Schwierigkeiten bei der Fehlersuche, dem Testen und 
der Dokumentation entstehen 
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WIE SIEHT ES MIT DER ZUKUNFT AUS? 

Es ist zu erwarten, daß in Zukunft eine Tendenz in Rich¬ 
tung höherer Programmiersprachen aus folgenden Grün¬ 
den vorhanden sein wird: 


• Programme scheinen immer aufwendiger und größer zu werden 

• Hardware und Speicher werden billiger 

• Software und Programmierer gewinnen an Erfahrung. 

• Speicherchips bekommen mehr Kapazität bei niedrigeren Kosten "pro Bit", so 
daß die tatsächlichen Einsparungen an Speicherkosten nicht mehr so stark 
ins Gewicht fallen. 

• Es werden geeignetere und effizientere höhere Programmiersprachen ent¬ 
wickelt. 

• Höhere Programmiersprachen werden weiter standardisiert. 

Die Programmierung von Mikroprozessoren in Assemblersprache ist jedoch 
keine aussterbende Kunst, wie es derzeit bei größeren Computern der Fall ist. 
Jedoch längere Programme, billigere Speicher und teurere Programmierer wer¬ 
den einen immer größeren Anteil der Software-Kosten bei den meisten Applika¬ 
tionen zur Folge haben Bei zahlreichen Anwendungen werden daher höhere 
Programmiersprachen Verwendung finden. 


ZUKÜNFTIGE 
TRENDS IN 
PROGRAM¬ 
MIER¬ 
SPRACHEN 
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WESHALB DIESES BUCH? 

Wenn die Zukunft scheinbar den höheren Programmiersprachen gehört, wozu 
dient dann ein Buch über Programmierung in Assembler-Sprache? Die Gründe 
sind: 

1) Die meisten gegenwärtigen Anwender von Microcomputern programmieren 
in Assemblersprache (mindestens 2/3 gemäß einer kürzlich eifolgten Umfra¬ 
ge). 

2) Viele Anwender von Mikrocomputern werden weiter in Assemblersprache 
programmieren, da sie deren detaillierte Steuerung benötigen. 

3) Bis jetzt ist noch keine allgemein verfügbare oder standardisierte höhere 
Programmiersprache entwickelt worden. 

4) Zahlreiche Anwendungen erforderndie Effizienz der Assemblersprache. 

5) Das gründliche Verständnis der Assemblersprache kann bei der Entwicklung 
höherer Sprachen helfen. 

Der Rest dieses Buches wird sich ausschließlich mit Assemblern und Program¬ 
mierung in Assemblersprache befassen. Es ist jedoch wünschenswert, daß die 
Leser wissen, daß die Assemblersprache nicht die einzige Alternative ist. Man 
sollte sorgfältig neue Entwicklungen beobachten, die möglicherweise eine we¬ 
sentliche Reduzierung der Programmierkosten bewirken, falls derartige Kosten 
ein wesentlicher Faktor für die jeweilige Anwendung ist. 
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Kapitel 2 
ASSEMBLER 


in diesem Kapitel werden die von Assemblern ausgeführten Funktionen be¬ 
schrieben, beginnend mit den Eigenschaften, die den meisten Assemblern ge¬ 
meinsam sind, bis zu weitergehenden Möglichkeiten wie Makros und bedingte 
Assemblierung Dieses Kapitel kann man jedoch zunächst überfliegen und 
erst dann ausführlicher lesen, wenn man mit der Materie vertrauter ist. 

EIGENSCHAFTEN VON ASSEMBLERN 

Wie bereits eingangs erwähnt, führen moderne Assembler nicht nur die Über¬ 
setzung von Mnemoniks in Assemblersprache in die entsprechenden Binärco¬ 
des durch. Es soll daher beschrieben werden, wie ein Assembler die Überset¬ 
zung von Mnemoniks ausführt, bevor zusätzliche Eigenschaften der Assembler 
behandelt werden. Abschließend wird erläutert, wie man Assembler verwen¬ 
det. 


ASSEMBLER-BEFEHLE 


Befehle (oder "Anweisungen”) der Assemblersprache wer¬ 
den in eine Anzahl von Feldern auf geteilt, wie aus Tabelle 
2-1 zu sehen ist. Das Operationscode-Feld ist das einzige 
Feld, das niemals leer sein darf. Es enthält immer entwe¬ 
der ein Befehls-Mnemonik oder eine Anweisung für den Assembler, genannt 
Pseudo-Befehl . Pseudo-Operation oder abgekürzt Pseudo-Op. 

Das Operanden- oder Adressenfeld kann eine Adresse oder Daten enthalten, 
oder auch leer sein. 

Die Felder für den Kommentar und das Namensfeld (Labelfield) können nach 
Bedarf verwendet werden. Der Programmierer kann einen Namen oder eine 
Markierung (label) einem Befehl zuweisen oder einen Kommentar zur 
persönlichen Bequemlichkeit verwenden, z.B. um das Programm leichter ver¬ 
wendbar und lesbar zu machen. 


ASSEMBLER¬ 

SPRACHEN¬ 

FELDER 
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Tabelle 2-1 Die Felder eines Assemblersprachen-Befehls. 


Marken- 

Feld 

Operationscode 
oder Mnemonik- 
Feld 

Operanden¬ 
oder Adressen- Kommentar-Feld 

Feld 

START 

LDA 

VAL1 ;LADE ERSTE ZAHL IN A 


ADC 

VAL2 ;ADDIERE ZWEITE ZAHL ZU A 


STA 

SUM .SPEICHERE SUMME 

NEXT 

9 

•> .NÄCHSTERBEFEHL 

VAL1 

*-*+i 


VAL2 

*-»+i 


SUM 

•-vi 



Tabelle 2-2. Standard-Begrenzungszeichen des 6502-Assemblers. 


'Zwischenraum' 


; oder I 


zwischen Markierung (Label) und Operationscode 
und zwischen Operationscode und Adresse 
zwischen Operanden im Adressen-Feld 
vor einem Kommentar 


Beachten Sie, daß 6502-Assembler sehr stark variieren und einige diese 
Begrenzer nicht verwenden. 


Natürlich muß dem Assembler auf irgendeine Weise mit- FORMAT 

geteilt werden, wo ein Feld endet und das nächste be- - 

ginnt. 

Assembler, die mit einer Eingabe über Lochkarten arbeiten, fordern häufig , daß 
jedes Feld in einer speziellen Kartenspalte beginnt. Dies stellt ein festes 
Format dar. Feste Formate sind jedoch unbequem und lästig für den Program¬ 
mierer. Die Alternative hierzu ist ein freies Format, bei dem die Felder an belie¬ 
biger Stelle auf einer Zeile erscheinen können. 

Wenn der Assembler die Position auf der Zeile zur Tren¬ 
nung der Felder nicht verwenden kann, so muß er etwas an¬ 
deres zu Hilfe nehmen 
Die meisten Assembler benützen ein spezielles Symbol oder Begrenzungs- 
Zeichen (delimiter) am Beginn oder Ende jedes Feldes. Das am meisten ge 
brauchliche Begrenzungszeichen ist das Zeichen für den Zwischenraum. Kom¬ 
mata. Punkte, Strichpunkte. Schrägstriche, Fragezeichen und andere Zeichen, 
die anderweitig nicht verwendet werden, können in Programmen in Assembler¬ 
sprache eingesetzt werden und als Begrenzungszeichen dienen Tabelle 2-2 
enthält die des 6502 standardisierten Begrenzungszeichen 




2-2 


Mit Begrenzungszeichen muß man jedoch etwas vorsichtig sein. Manche As¬ 
sembler sind sehr empfindlich gegen zusätzliche Zwischenräume oder das 
Auftreten von Begrenzungszeichen in Kommentaren oder Marken. Ein gut ge¬ 
schriebener Assembler wird mit diesen kleineren Problemen leichtfertig, aber 
manche Assembler sind nicht so gut abgefaßt. Um derartige Probleme zu ver¬ 
meiden, können folgende Regeln behilflich sein: 

1) Verwenden Sie keine zusätzlichen Zwischenräume, speziell nach Kommata, 
mit denen Operanden getrennt werden 

2) Verwenden Sie keine Begrenzungszeichen in Namen oder Marken. 

3) Verwenden Sie Standard-Begrenzungszeichen auch dann, wenn Ihr Assem¬ 
bler diese nicht benötigt. Dann werden diese Programme für jeden Assem¬ 
bler annehmbar 


MARKEN (LABELS) 


MARKEN- 

Das Markenfeld ist das erste Feld eines Befehls in As- felD 

semblersprache. Es kann auch leer sein. -! 

Wenn eine Marke vorliegt, dann definiert der Assembler die Marke als äqui¬ 
valent mit der Adresse des Speicherplatzes, in den das erste Byte des Ob- 
iekt-Programmes. das sich aus diesem Befehl ergibt, geladen wird. Man 
kann danach die Marke als Adresse oder als Daten in einem anderen 
Adressenfeld eines Befehls verwenden. Der Assembler wird die Marke durch 
den zugewiesenen Wert ersetzen, wenn er ein Objektprogramm erzeugt. 


Marken werden am häufigsten in Sprung- Aufruf- oder MARKEN IN 
Verzweigungs-Befehlen verwendet. Diese Befehle bringen SPRUNG- 
einen neuen Wert in den Befehlszähler und ändern BEFEHLEN 
somit die normale sequentielle Ausführung von Befehlen. 

JUMP 1 50 18 bedeutet "Plaziere den Wert 150 1S in den Befehlszähler". Der näch¬ 
ste auszuführende Befehl wird derjenige im Speicherplatz 150 1B sein. Der 
Befehl JUMP START bedeutet "Piaziere den Wert, der der Marke START zuge¬ 
wiesen wurde, in den Belehlszähler’ Der nächste auszuführende Befehl wird 
derjenige im Speicherplatz sein, der zur Marke START gehört Tabelle 2-3 ent¬ 
hält ein Beispiel. 


Tabelle 2-3. Zuweisung und Verwendung einer Markierung 



Wenn die Maschinensprachen-Version dieses Programms ausgeführt 
wird, so bewirkt der Befehl SPRINGE ZU START, daß die Adresse des mit 
START markierten Befehls in den Befehlszähler plaziert wird. Dieser 
Befehl wird dann ausgeführt. 
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Weshalb werden Marken verwendet? Hier sind einige Gründe: 

1) Eine Marke erleichtert das Auffinden und Ennnern einer Programmstelle. 

2) Die Marke kann für die Korrektur eines Programmes verschoben werden. 
Man braucht einen darauf folgenden Befehl, der die Marke verwendet, nicht 
ändern. Der Assembler führt alle erforderlichen Änderungen automatisch 
selbst aus. 

3) Der Assembler oder Lader kann das ganze Programm 
verschieben, indem er eine Konstante (eine sogenannte 
Verschiebungs Konstante) zu jeder Adresse addiert, 
der eine Marke zugewiesen wurde. Man kann daher das 
Programm verschieben, um das Einsetzen anderer Programme zu gestatten 
oder um einfach den Speicher neu zu ordnen 

4) Das Programm ist einfacher in der Anwendung als ein Bibliotheks-Pro¬ 
gramm, d.h. es kann temand unser Programm einfacher übernehmen und es 
zu einem völlig anderen Programm hinzufügen. 

5) Man braucht sich keine Speicher-Adressen auszudenken Die Festlegung 
von Speicheradressen ist besonders schwierig mit Mikroprozessoren, die 
Befehle mit unterschiedlicher Länge besitzen. 

Sie sollten Jedem Befehl eine Marke zuweisen , auf den Sie sich vielleicht 

später beziehen wollen. 


Die nächste Frage ist, welche Marken man verwenden 
soll. Durch die Assembler-Syntax wird häufig die An¬ 
zahl der Zeichen begrenzt (gewöhnlich 5 oder 6), das erste 
Zeichen muß meist ein Buchstabe sein, und die folgenden Zeichen müssen 
meist Buchstaben, Zahlen oder ein spezielles Zeichen sein. Innerhalb dieser Be¬ 
grenzungen hat man freie Wahl. 

Man verwendet vorteilhafterweise Markierungen, die auf ihre Verwendung 
schließen lassen, d.h. mnemotechnische Marken. Typische Beispiele hierfür 
wären ADDW in einem Programm, bei dem ein Wort zu einer Summe addiert 
wird, SRETX in einem Programm, in dem nach dem ASXCII-Zeichen ETX ge¬ 
sucht (search for) wird, oder NKEYS für einen Platz im Datenspeicher, das 
die Anzahl der Tasteneingaben (number of key entnes) enthält. Wenn sich 
aus der Bezeichnung einer Marke auf ihre Verwendung schließen läßt, so 
kann man sich diese leichter merken, und sie vereinfachen die Programm- 
Dokumentation. Manche Programmierer ziehen es vor, ein Standard-Format 
für Marken zu verwenden, die beispielsweise mit L0000 beginnen. Dadurch 
ergibt sich bei diesen Marken von selbst die entsprechende Reihenfolge (wo¬ 
bei man einige Zahlen überspringen kann, um nachtragliohe Einfügungen zu er¬ 
möglichen); sie machen jedoch die Dokumentation nicht sehreinfach. 


Einige einfache Regeln für die Auswahl von Marken 
vermeiden Schwierigkeiten. Die Einhaltung folgender 
Regeln ist empfehlenswert' 


1 ) Verwenden Sie keine Marken, die mit Operationscodes oder anderen Mne- 
moniks übereinstimmen. Die meisten Assembler gestatten eine derartige 
Verwendung nicht. Bei anderen ist dies zwar der Fall, aber es kann zu Ver¬ 
wechslungen führen. 

2) Verwenden Sie keine Marken die länger sind, als die vom Assembler zuge 
lassen. Assembler besitzen verschiedene Kurzungsregeln. 

3) Vermeiden Sie spezielle Zeichen (nicht-alphabetische und nicht¬ 
numerische), sowie Kleinbuchstaben. Manche Assembler gestatten deren 
Verwendung nicht, andere verwenden einige hiervon. Man beschränkt sich 
am besten auf Großbuchstaben und Zahlen. 

4) Beginnen Sie jede Markierung mit einem Buchstaben. Derartige Marken wer¬ 
den immer angenommen. 

5) Verwenden Sie keine Marken, die sich mit anderen verwechseln lassen. Ver¬ 
meiden Sie die Buchstaben I, O, Z und die Zahlen 0, 1 und 2. Vermeiden Sie 
ferner Anordnungen wie XXXX und XXXXX, sie lassen sich schwer unter¬ 
scheiden. 

6 ) Wenn Sie nicht sicher sind, daß eine Marke gestattet ist, dann verwenden Sie 
diese auch nicht. Es ist kein besonderer Vorteil genau zu erfahren, was der 
Assembler annehmen wird. 

Dies sind gutgemeinte Empfehlungen. Man muß sie nicht befolgen, kann aber 

auf diese Weise unangenehme Probleme vermeiden. 


ASSEMBLER-OPERATIONSCODES (MNEMONiKS) 

Die hauptsächliche Aufgabe des Assemblers ist die Übersetzung von Mnemo- 
niks in Ihre äquivalenten binären Operationscodes. Der Assembler führt dies 
unter Verwendung einer festgelegten Tabelle aus, ebenso wie man es bei einer 
händischen Assemblierung tun würde. 

Der Assembler muß jedoch mehr leisten, als nur die Übersetzung der Opera¬ 
tionscodes. Er muß irgendwie bestimmen, wieviele Operanden der Befehl be¬ 
nötigt und welcher Art diese sind. Dies kann ziemlich komplex sein, da manche 
Befehle (wie ein HALT) keine Operanden besitzen. Andere dagegen (wie etwa 
ein Additions- oder Sprungbefehl) besitzen einen Operanden, während wieder¬ 
um andere (wie ein Transfer zwischen Registern oder eine Mehr-Byte Ver¬ 
schiebung) dagegen zwei erfordern. Manche Befehle gestatten sogar alternative 
Anwendungen. z.B. besitzen manche Computer Befehle (wie Verschieben oder 
Löschen), die sich entweder auf den Akkumulator oder auf einen Speicherplatz 
beziehen Es soll nicht weiter besprochen werden, wie ein Assembler diese Un- 
tersche idungen trifft, wir wollen nur festhalten daß er dies tun muß. 


VERSCHIE¬ 

BUNGS¬ 

KONSTANTE 


AUSWAHL 
VON MAKREN 


REGELN FÜR 
MARKIE¬ 
RUNGEN 
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PSEUDO-OPERATIONEN 


Manche Assemblersprachen-Befehle werden nicht direkt 
in Maschinensprachen-Befehle übersetzt. Diese Befehle 
stellen "Anweisungen" f iir den Assembler dar. 

Sie weisen das Programm bestimmten Speicherbereichen zu, definieren Sym¬ 
bole, bestimmten Bereichen im RAM für zeitweilige Datenspeicherung, plazie¬ 
ren Tabellen oder andere feste Daten in den Speicher und führen 
andere Haushaltungsfunktionen aus. 

Um diese Anweisungen oder Pseudo-Operationen zu verwenden, plazierl ein 
Programmierer die Mnemoniks der Pseudo-Operationen in das Operations¬ 
code-Feld und eine Adresse oder Daten in das Adressenfeld, wenn eine be¬ 
stimmte Pseudo-Operation dies erfordert 

Die am meisten gebräuchlichsten Pseudo-Operationen sind: 

DATA 

EQUATE (-) oder DEFINE 

ORIGIN 

RESERVE 

Verbindende Pseudo-Operationen (zur Verbindung getrennter Programme) 
sind: 

ENTRY 

EXTERNAL 

Verschiedene Assembler verwenden auch unterschiedliche Bezeichnungen für 
diese Operationen, ihre Funktionen sind jedoch die gleichen. Pseudo-Opera¬ 
tionen für Haushaltungsfunktionen sind folgende: 

END 

LIST 

NAME 

PAGE 

SPACE 

TITLE 

Wir werden diese Pseudo-Operationen kurz besprechen, obwohl ihre Funktio¬ 
nen gewöhnlich offensichtlich sind. 
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DIE PSEUDO-OPERATION DATA 


Die Pseudo-Operation DATA gestattet dem Programmierer die Eingabe fester 
Daten in den Programmspeicher. Diese Daten können enthalten: 

Nachschlag Tabellen 

Code-Umwandlungstabellen 

Nachrichten 

Synchronisationsmuster 

Schwellwerte 

Namen 

Koeffizienten für Gleichungen 

Kommandos 

Umrechnungs-Faktoren 

Bewe rtungs-Faktoren 

Charakteristische Zeiten oder Frequenzen 

Unterprogramm-Adressen 

Schlüssel-Identifizierungen 

Testmuster 

Muster für Zeichenerzeugung 

Identifizierungsmuster 

Gebührentabellen 

Standardformen 

Maskier-Muster 

Zustands-Übergangstabellen 

Die Pseudo Operation DATA behandelt die Daten als ständigen Teil des 
Programmes. 

Das Format der Pseudo-Operation DATA ist gewöhnlich sehr einfach. Ein 
Befehl wie 

DZCON DATA 12 

wird die Zahl 12 in den nächsten verfügbaren Speicherplatz bringen und die¬ 
sem Platz die Bezeichnung DZCON zuweisen. Gewöhnlich besitzt jede Data- 
Pseudo-Operation eine Marke, es sei denn, sie ist eine aus einer Serie von 
Data-Pseudo-Operationen. Die Daten und Marken können in jeder beliebigen 
Form vorliegen, die vom Assembler zugelassen ist. 

Die meisten Assembler gestatten umfangreichere DATA Befehle, mit denen 
eine große Anzahl von Daten zur gleichen Zeit gehandhabt werden können, 

z.B.: 


EMESS DATA 'ERROR' 

SQRS DATA 1,4,9,16,25 
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Ein einzelner Befehl kann zahlreiche Worte des Programmspeichers füllen und 
wird nur durch die Länge einer Zeile begrenzt. Wenn man nicht alle auf einer 
Zeile unterbringt, kann immer ein DATA-Belehl auf den anderen folgen. z.EL: 


MESSG DATA 
DATA 
DATA 
DATA 
DATA 
DATA 


'NOW IS THE' 

'TIME FOR ALL' 
'GOOD MEN’ 

’TO COME TO THE’ 
'AID OFTHEIR' 
’COUNTRY' 


Assembler für Mikroprozessoren besitzen normalerweise einige Varianten der 
Standard-Pseudo-Operaton DATA. DEFINE BYTE oder FORM CONSTANT 
BYTE handhaben B-Bit-Zahlen. DEFINE WORD oder FORM CONSTANT WORD 
handhaben 16-Bit-Zahlen oder Adressen. Andere spezielle Pseudo-Operationen 
können zeichencodierte Daten verarbeiten. 


DIE PSEUDO-OPERATION EQUATE (oder DEFINE) 

Die Pseudo-Operation EQUATE gestattet dem Program¬ 
mierer das "Gleichsetzen" von Namen und Adressen oder 
Daten. Diese Pseudo-Operation wird meist mit dem Mne¬ 
monik EQU oder= bezeichnet. 

Die Namen können sich auf Baustein-Adressen, numerische Daten, Start- 
Adressen. feste Adressen etc. beziehen. 

Die Pseudo-Operation EQUATE weist den numerischen Wert in ihrem Operan¬ 
denfeld dem Namen in ihrem Markenfeld zu. Hier sind zwei Beispiele: 

TTY EOU 5 

LAST EOU 5000 

Die meisten Assembler gestatten die Definition einer Marke mit den Ausdrücken 
einer anderen, z.B.: 

LAST EQU FINAL 

ST1 EOU START+1 

Die Marke im Operandenfeld muß natürlich vorher definiert werden. Häufig kann 
das Operandenfeld komplexere Ausdrücke enthalten, wie wir später sehen wer¬ 
den. Die Zuweisung doppelter Namen (zwei Namen für die gleichen Daten oder 
Adressen) kann sehr nützlich sein, wenn man Programme Zusammenlegen will, 
die verschiedene Namen für die gleiche Variable (oder unterschiedliche Aus¬ 
drucksweise lür scheinbar gleiche Namen) verwenden. 


Es ist zu beachten, daß eine EQU-Pseudo-Operation nicht 
bewirkt, daß der Assembler irgend etwas in den Pro¬ 
grammspeicher plaziert. Der Assembler plaziert einfach 
einen zusätzlichen Namen in eine Tabelle (eine sogenannte Symbol-Tabelle). 

Diese Tabelle, anders als die Mnemoniks-Tabelle, muß in einem RAM liegen, da 
sie sich mit jedem Programm ändert. Das Assembler-Programm wird immer 
einen Teil eines RAMs benötigen, um die Symbol-Tabelle aufzubewahren. Je 
mehr RAM zur Verfügung steht, desto mehr Symbole kann sie aufnehmen. Die¬ 
ses RAM wird zusätzlich zu allem benötigt, was der Assembler an zeitweiligem 
Speicher braucht. 


SYMBOL¬ 

TABELLE 


DEFINITION 
VON NAMEN 


Wann verwendet man einen Namen? Die Antwort ist, wann 
immer man einen Parameter hat, den man andern möchte 
oder der irgend eine Bedeutung neben seinem gewöhnli¬ 
chen numerischen Wert besitzt. Gewöhnlich erfolgt eine Zuweisung von Namen 
zu Zeit-Konstanten, Baustein Adressen, Maskier Mustern, Umwandlungsfakto¬ 
ren und ähnlichen. Ein Name wie DELAY, TTY, KBD, KROW oder OPEN macht 
es nicht nur einfacher, den Parameter zu ändern, sondern erleichtert auch die 
Programm-Dokumentation. Man weist Namen auch Speicherplätzen zu, die 
einen speziellen Zweck haben. Sie können Daten aufbewahren, den Start des 
Programms markieren, oder für unmittelbare Speicherung zur Veilügung 
stehen. 

Welche Namen verwendet man? Man verwendet am 
besten Namen nach den gleichen Grundsätzen wie bei 
Markierungen, wobei hier besonders bedeutungsvolle 
Namen empfehlenswert sind Weshalb soll man den Fern¬ 
schreiber (teletypewriter) nicht TTY anslatt X15 nennen, eine Bit-Zeit¬ 
verzögerung BTIME oder BTDLY anstatt WW, die Nummer der "GO"-Taste (key) 
auf einer Tastatur GOKEY anstatt ''PFERD?" Diese Ratschläge scheinen trivial 
zu sein, jedoch eine überraschende Anzahl von Programmierern verwenden sie 
nicht. 


Wohin wird man die Equate-Pseudo-Operationen plazie¬ 
ren? Die beste Stelle ist am Beginn des Programms, unter 
entsprechenden Kommentar-Uberschrifien wie E/A-Adres- 
sen, zeitweilige Speicherung, Zeitkonstanten oder Programmstellen. Dadurch 
lassen sich Definitionen leichter finden, wenn man sie ändern möchte, Ferner 
wird ein anderer Anwender imstande sein, alle Definitionen an einer zentralen 
Stelle zu übersehen. Offensichtlich verbessert diese Praxis auch die Dokumen¬ 
tation und erleichtert die Verwendung des Programmes. 

Definitionen, die nur in einem speziellen Unterprogramm verwendet werden, 
sollten am Beginn des Programmes aufscheinen. 


PLAZIERUNG 

VON 

DEFINITIONEN 


AUSWAHL 
VON NAMEN 


VERWENDUNG 
VON NAMEN 


DIE PSEUDO-OPERATION ORIGIN 

Die ORIGIN Pseudo-Operation (meist abgekürzt ORG) gestattet dem Program¬ 
mierer das Assemblieren von Programmen, Unterprogrammen oder Daten 
überall im Speicher. Programme und Daten können in verschiedenen Speicher¬ 
bereichen liegen, abhängig von der Speicher-Konfiguration. Start-Routinen, 
Unterbrechungs-Serviceroulinen und andere notwendige Programme können 
über den ganzen Speicher verteilt sein oder an bestimmten Adressen festliegen. 


Der Assembler enthält einen Stellenzähler (Location Coun¬ 
ter), der vergleichbar ist mit dem Befehlszähler des Com¬ 
puters, und der die Speicherstelle des nächsten zu verarbeitenden Befehls 
oder Daten enthält. Eine ORG-Pseudo-Operation bewirkt, daß der Assembler 
einen neuen Wert in den Stellenzähler plaziert, gerade so wie ein Sprungbefehl 
bewirkt, daß die CPU einen neuen Wert in den Befehlszähler bringt. Die Ausga 
be des Assemblers braucht nicht nur Befehle und Daten zu enthalten, sondern 
muß auch dem Ladeprogramm angeben, wo es die Befehle und Daten in den 
Speicher plazieren soll 


STELLEN¬ 

ZÄHLER 
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Mikroprozessor-Programme enthalten häufig verschiedene ORtGIN-An- 
weisungen für folgende Zwecke. 

Rücksetz (Start)-Adressen 

Unterbrechungs-Service-Adressen 

Adressen von Fallen 

RAM-Speicher 

Speicherstapel 

Haupt-Programm 

Unterprogramme 

Speicheradressen, reserviert für Eingabe/Ausgabe-Bausteine 
oder spezielle Funktionen. 

Weitere ORtGlN Anweisungen können Platz für spatere Einfügungen schaffen. 
Tabellen oder Daten in den Speicher plazieren, oder freien RAM-Speicherraum 
Datenpuffern zuweisen. Programm- und Datenspeicher in Mikrocomputern kön¬ 
nen weit verstreute Adressen belegen, um die Hardware-Entwicklung zu verein¬ 
fachen. 

Typische ORIGIN-Anweisungen sind: 

ORG RESET 

ORG 1000 

ORG INT3 

Manche Assembler nehmen standardmäßig einen Wert von Null als ORIGIN, 
wenn der Programmierer keine ORG-Anweisung an den Beginn des Program¬ 
mes legt Das ist bequem, wir empfehlen tedoch die Verwendung einer ORG- 
Anweisung um Verwirrung zu vermeiden. 


DIE PSEUDO-OPERATION RESERVE 

Die Reserve-Pseudo-Operation gestattet dem Program¬ 
mierer die Zuweisung von RAM-Bereichenfür 
verschiedene Zwecke wie Daten-Tabellen, zeitweilige Speicherung, indirekte 
Adressen, einen Stapel etc. 

Bei der Verwendung der Pseudo-Operation RESERVE weist man einen Namen 
einem Speicherbereich zu und gibt die Anzahl der zuzuweisenden Speicher¬ 
plätze an. Hier sind einige Beispiele: 


NOKEY RESERVE 1 

TEMP RESERVE 50 

VOLTG RESERVE 80 

BUFR RESERVE 1*0 

Man kann die Pseudo-Operation RESERVE zur Reservierung von Speicherplät¬ 
zen im Programmspeicher oder im Datenspeicher verwenden Die RESERVE 
p seudo-Operation besitzt jedoch eine größere Bedeutung, wenn sie auf den Da¬ 
tenspeicher angewendet wird 
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tn der Praxis erhöhen alle RESERVE Pseudo-Operationen nicht den Stellen- 
, : ähler (Location Counter) des Assemblers durch den Betrag, der im Operan¬ 
denfeld angegeben ist Der Assembler erzeugt tatsächlich überhaupt keinerlei 
Obtektcode. 

Beachten Sie die folgenden Eigenschaften von RESERVE: 

1) Die Markierung der RESERVE Pseudo Operation wird dem Wert der ersten 
reservierten Adresse zugewiesen. Beispielsweise reserviert die Sequenz: 

TEMP RESERVE 20 


20 Bytes des RAMs und weist dem Namen TEMP der Adresse des ersten 
Bytes zu. 

2) Man muß die Anzahl der zu reservierenden Speicherstellen spezifizieren. Es 
gibt hier keinen Standardfall. 

3) Es werden keine Daten in die reservierten Speicherstellen plaziert. Wenn sich 
Daten zufällig in diesen Speicherstellen befinden, werden sie dort belassen 

Einige Assembler gestatten dem Programmierer die Pia- LISIE- 

zierung von Anfangswerten in das RAM. Es ist dringend zu RUNG Alu , 

empfehlen, daß man diese Eigenschaft nicht verwendet. Es DES RAMs_ 

wird hierbei angenommen, daß das Programm (zusammen mit den Anfangswer¬ 
ten) von einem externen Gerat geladen wird (z.B Lochstreifen oder Floppy 
Disks), jedesmal, wenn es ablauft. Die meisten Mikroprozessor-Programme be 
finden sich andererseits in nicht-flüchtigen ROMs und starten beim Einschalten 
der Betriebsspannung. In derartigen Situationen behält das RAM seinen Inhalt 
nicht, und es wird auch nicht neu geladen. Daher sind immer Befehle vorzuseh¬ 
en, die das RAM in dem eintsprechenden Programm initialisieren. 


BINDE-PSEUDO-OPERATIONEN 

Wir brauchen häufig Anweisungen in einem Programm EXTERNE 
oder Unterprogramm, die Namen verwenden, die anders- REFERENZEN 
wo definiert wurden. Derartige Namen nennt man externe 
Referenzen. 

Hierzu ist ein spezielles Binde-Programm (linking program) erforderlich, um die 
Werte tatsächlich einzusetzen und zu bestimmen, ob irgendwelche Namen nicht 
oder doppelt definiert wurden. 

Die Pseudo-Operation EXTERNAL, gewöhnlich EXT abgekürzt, zeigt an, daß 
der Name anderswo definiert wurde. 

Die Pseudo-Operation ENTRY, gewöhnlich ENT abgekürzt, zeigt an, daß der 
Name für den Gebrauch an beliebiger Stelle verfügbar ist, d.h. er ist in 
diesem Programm definiert 

Die genaue Art und Weise, in der Binde-Pseudo-Operationen ausgeführt wer¬ 
den, variiert sehr weit von Assembler zu Assembler Wir werden uns daher auf 
derartige Pseudo-Operationen weiterhin nicht beziehen, sie sind jedoch in 
praktischen Anwendungen sehr nützlich. 
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HAUSHALTUNGS-PSEUDO-OPERATIONEN 


ADRESSEN UND DAS OPERANDENFELD 


Es gibt verschiedene Haushaltungs-Pseudo-Operationen, die den Betrieb des 
Assemblers und seine Programm-Auflistung eher beeinflussen, als das Aus¬ 
gangsprogramm selbst. Gebräuchliche Haushaltungs-Pseudo-Opertationen 
beinhalten: 


Oie meisten Assembler gestatten dem Programmierer ziemlich viel Freiheit 
bei der Beschreibung des Inhalts des Operanden- oder Adressenfeldes. Aber 
erinnern wir uns daran, daß der Assembler eigene Namen für Register und 
Befehle besitzt und andere eigene Namen besitzen kann. 


• END. durch die das Ende des Quellenprogrammes in Assemblerspra¬ 
che markiert wird. 

• LIST, das dem Assembler sagt, das Quellenprogramm zu drucken. 
Manche Assembler gestatten Variationen wie NO LIST oder 
LISTSVMBOL. 

• NAME oder TITLE, womit ein Name oben auf iede Seite der Auflistung 
gedruckt wird. 

• PAGE oder SPACE, wodurch zur nächsten Seite oder nächsten Zeile 
gesprungen wird, und das Aussehen der Auflistung verbessert und sie 
dadurch lesbarer macht. 

• PUNCH, wodurch der auleinanderfolgende Objektcode auf den Loch¬ 
streifen-Stanzer übertragen wird Die Pseudo-Operation kann in vielen 
Fällen eine Standard-Option sein, und ist deshalb nicht notwendig. 


MARKIERUNGEN BEI PSEUDO-OPERATIONEN 

Anwender möchten häufig gerne wissen, ob oder wann sie eine Markierung ei¬ 
ner Pseudo-Operation zuweisen können. Hierzu ist folgendes zu empfehlen: 

1) Alle EQUATE-Pseudo-Operationen müssen Markierungen besitzen. Sie 
haben andernfalls keinen Sinn, da ihr Zweck in der Definition der Bedeutung 
dieser Markierung besteht, 

2) DATA und RESERVE-Pseudo-Operationen sollten gewöhnlich Markierungen 
besitzen. Die Markierung identifiziert den ersten verwendeten oder zugewie¬ 
senen Speicherplatz. 

3) Andere Pseudo-Operationen sollten keine Markierungen haben. Manche 
Assembler gestatten, daß derartige Pseudo-Operationen Markierungen be¬ 
sitzen. die Bedeutung der Markierungen ist jedoch unterschiedlich und nicht 
standardisiert. Diese Praxis ist nicht zu empfehlen 


Einige gebräuchliche Optionen für das Operandenfeld 
sind: 


1) Dezimalzahlen 

Die meisten Assembler nehmen an, daß alle Zahlen Dezimalzahlen sind, 
außer sie sind anderweitig markiert. Daher bedeutet: 

ADD 100 

"Addiere den Inhalt des Speicherplatzes 100 )o 
Akkumulators” 


2) Andere Zahlensysteme 

Oie meisten Assembler nehmen auch binäre, oktale 
oder hexadezimale Eingaben an. Man muß jedoch 
derartige Zahlensysteme auf irgendeine Weise identifizieren, z B. in¬ 
dem man der Zahl ein Identifikationszeichen oder Buchstaben vorausgehen 
läßt. Hier sind einige gebräuchliche Kennzeichnungen: 

B oder % für binär 

0,@, O. oder C für oktal (gewöhnlich vermeidet man jedoch den 
Buchstaben O, damit keine Verwechslung mit 0 entsteht). 

H oder $ für hexadezimal (oder Standard-BCD) 

D für dezimal. D kann jedoch weggelassen werden, da es ein Stan¬ 
dardfall Ist. 

Assembler benötigen im allgemeinen Hexadezimalzahlen, um mit einer Ziffer 
zu beginnen (z.B. 0A36 anstatt A36). damit sie zwischen Zahlen und Namen 
oder Markierungen unterscheiden können. Es ist empfehlenswert, Zahlen in 
der Basis einzugeben, in der ihre Bedeutung am deutlichsten ist, d.h. dezi¬ 
male Konstanten in dezimal, Adressen und BCD-Zahlen in hexadezimal. 
Maskier-Muster oder Bit-Ausgänge in binär, wenn sie kurz sind und in hexa¬ 
dezimal. wenn sie lang sind. 

3) Namen 

Namen können im Operandenfeld erscheinen. Sie werden wie Daten behan¬ 
delt, die sie darstellen. Aber erinnern wir uns daran, daß es einen Unter¬ 
schied zwischen Daten und Adressen gibt. Die Sequenz 

FIVE EQU 5 

ADDA FIVE 

wird den Inhalt des Speicherplatzes 0005 (nicht notwendigerweise die Zahl 5) 
zum Inhalt des AkkumulatorsA addieren. 


zum Inhalt des 


NICHT¬ 

DEZIMALE 

ZAHLEN¬ 

SYSTEME 


DEZIMAL¬ 
DATEN ODER 
ADRESSEN 
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4) Der momentane Wert des Speicherzählers (gewöhnlich bezeichnet als 
•oder$). 

Dies ist vor allem bei Sprungbefehlen von Bedeutung, Z B. bewirkt 
JUMP -+6 

einen Sprung zum Speicherplatz sechs Worte hinter dem Wort, das das erste 
Byte des Sprungbefehles enthält: 


6 Speicher¬ 
plätze 



Speicher 





/ 






\ 




\ 











SPRU NG * +€ zum hier gespeicherten Code 


Spnnge hierher 


Die meisten Mikroprozessoren besitzen Zwei- und Dreiwort-Befehle. Da¬ 
her wird man Schwierigkeiten bei der genauen Bestimmung haben, wie 
weit voneinander entfernt zwei Assemblersprachen-Anweisungen sind. 
Die Verwendung von Versetzungen (otfsets) vom Stellenzähler resultieren 
daher häufig in Fehlern, die man vermeiden kann, wenn man stattdessen 
Markierungen verwendet. 

ASCII- 

5) Zeichencodes ZEICHEN 

Die meisten Assembler gestatten die Eingabe von Text - 

als ASCII-Zeichenfolgen (strings). Derartige Zeichenfolgen können sich ent¬ 
weder zwischen einfachen oder doppelten Anführungszeichen befinden. Zei¬ 
chenfolgen können auch ein Anfangs- oder Abschlußsymbol verwenden, wie 
etwa A oder C, Einige wenige Assembler gestatten auch EBCDiC-Zeichen- 
folgen. 

Es ist zu empfehlen, daß man Zeichenfolgen für alle Arten von Text verwen¬ 
det, Es verbessert die Deutlichkeit und Lesbarkeit des Programms 


6) Kombination von 1 bis 5 mit arithmetischen, logischen 
oder speziellen Operatoren. Nahezu alle Assembler ge¬ 
statten einfache arithmetische Kombinationen, wie 
etwa START+1 Einige Assembler erlauben auch eine 
Multiplikation, Division, logische Funktionen. Verschie¬ 
bungen, etc. Diese werden als Ausdrücke (expressions) 
bezeichnet. Es ist zu beachten, daß der Assembler Ausdrücke während der 
Assemblierzeit prüft. Auch wenn ein Ausdruck im Operandenfeld Multiplika¬ 
tionen enthalten kann, so wird man nicht imstande sein, die Multiplikation in 
der Logik des eigenen Programmes zu verwenden, außer man schreibt ein 
Unterprogramm für diesen speziellen Zweck, 

Assembler unterscheiden sich darin, welche Ausdrücke sie annehmen und 
wie sie diese interpretieren. Komplexe Ausdrücke ergeben schwer lesbare 
und schwer verständliche Programme. 


ARITHME¬ 

TISCHE 

UND LOGISCHE 
AUSDRÜCKE 


Während dieses Abschnittes wurden mehrere Empfehlungen gegeben, sie sol¬ 
len hier wiederholt und ergänzt werden. Im Allgemeinen soll man auf Deutlich¬ 
keit und Einfachheit achten. Es lohnt sich nicht, ein Experte für besondere Fein¬ 
heiten des Assemblers zu sein, oder sehr komplizierte Ausdrücke zu verwen¬ 
den, wenn dies nicht erforderlich ist. 

Es ist folgendes zu empfehlen: 

- Verwenden Sie das deutlichste Zahlensystem oder Zeichencode für Daten. 

- Masken und BCD-Zahlen in dezimal, ASCH Zeichen in oktal, oder gewöhnli¬ 
che numerische Konstanten in hexadezimal haben keinen Zweck und sollten 
daher nicht verwendet werden. 

- Vergessen Sie nicht, Daten und Adressen zu unterscheiden. 

- Verwenden Sie keine Versetzungen (offsets) vom Stellenzähler 

- Halten Sie Ausdrücke einfach und deutlich. Verwenden Sie keine ausgefallen¬ 
en Eigenschaften des Assemblers. 


BEDINGTE ASSEMBLIERUNG 


Manche Assembler gestalten das Einschließen oder Ausschließen von Teilen 
des Quellprogramms, abhängig von Bedingungen, die zur Assemblierzeit vor¬ 
handen sind. Dies wird bedingte Assemblierung genannt. Sie gibt dem Assem¬ 
bler etwas von der Flexibilität eines Kompilierers. Die meisten Mikrocomputer- 
Assembler haben begrenzte Möglichkeiten für eine bedingte Assemblierung. 

IF COND 

.(CONDITIONAL PROGRAM) 


ENDlF 

Wenn der Ausdruck C*ND während der Assemblierzeit gültig ist, dann sind die 
Befehle zwischen IF und ENDlF (zwei Pseudo-Operationen) im Programm ent¬ 
halten. 

Typische Anwendungen von bedingter Assemblierung sind: 

1) Das Einschließen oder Weglassen zusätzlicher Variablen. 

2) Das Unterbringen von Diagnostik-Routinen in Testläufen. 

3) Die Verwendung von Daten mit unterschiedlichen Bit-Längen. 

4) Die Schaffung spezieller Versionen eines allgemeinen Programmes. 

Unglücklicherweise tendiert die bedingte Assemblierung zum Verwirren von 
Programmen und machten sie schwierig zu lesen Es soll daher die bedingte 
Assemblierung nur verwendel werden, falls dies erforderlich ist. 
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MAKROS 


Man wird häufig finden, daß spezielle Sequenzen von Be¬ 
fehlen mehrfach in einem Quellprogramm aufscheinen. 

Wiederholte Befehls-Sequenzen können Forderungen unse¬ 
rer Programm-Logik wiedergeben, oder sie können 
Unvollkommenheilen in dem Befehlssatz unseres Mikroprozessors ausgleichen. 
Man kann das wiederholte Schreiben der gleichen Befehl Is Sequenz vermeiden, 
wenn man ein Makro verwendet. 

Makros gestatten die Zuweisung eines Namens zu einer Befehls-Sequenz. Man 
kann dann den Makro-Namen im Quellprogramm verwenden, anstatt der wie¬ 
derholten Befehls-Sequenz. Der Assembler wird den Makro-Namen durch die 
entsprechende Sequenz von Befehlen ersetzen. Dies kann wie folgt dargestellt 
werden: 


DEFINITION 
EINER 
SEQUENZ 
VON BEFEHLEN 


Quellprogramm 


Objekt-Programm 


MAC1 


MACRO 
Befehl Ml 
Befehl M2 
Befehl M3 


ENOM 


(Makro-Definihon) 


(Ende der MekrO-Definifion) 


Befehl Pi (Hauplprogramm) 
Befehl P2 
Befehl P3 


MAC1. 


Befehl P4 | 
Befehl P5 I 
Befehl P6 /' 
BefehlP7 J 


MAC1- 

BefehlPB I 
Befehl P9 { 

MACI_ 

Befehl PlO » 
Befehl Pi 1 ( 



Befehl Pi 
Befehl P2 
Befehl P3 

Befehl Ml 
Befehl M 2 
Befehl M3 

Befehl P4 
Befehl P5 
Befehl P6 
Befehl P7 

Befehl Ml 
Befehl M2 
Befehl M3 

Befehl PQ 
Befehl P9 

Befehl Ml 
Befehl M2 
Befehl M3 

Befehl PlO 
Befehl PlO 


Makros sind nicht dasselbe wie Unterprogramme. Ein Unterprogramm tritt nur 
einmal in einem Programm aut, und die Programm-Ausführung verzweigt zu 
diesem Unterprogramm. Ein Makro wird zu einer tatsächlichen Befehls-Sequenz 
erweitert, jedes Mal wenn der Makro auftritt. Daher bewirkt der Makro keine Ver¬ 
zweigung. 


Makros besitzen folgende Vorteile: VORTEILE 

VON MAKROS 

1 ) Kürzere Quellprogramme - 

2) Bessere Programm-Dokumentation. 

3) Verwendung von fehlerfreien Befehls-Sequenzen. Sobald der Makro fehlerfrei 
gemacht wurde, ist man sicher, daß eine einwandfreie Befehls-Sequenz bei 
jeder Verwendung des Makros zur Verfügung hat 

4) Einfacher Austausch. Man ändert die Makro-Delinition und der Assembler 
führt die Änderung aus. jedesmal wenn der Makro verwendet wird. 

5) Einschließen von Kommandos, Schlüsselworten oder anderen Computer- 
Befehlen in den grundlegenden Befehlssatz. Man verwendet Makros zur Er¬ 
weiterung oder Erläuterung des Befehlssatzes. 


NACHTEILE 
VON MAKROS 


Die Nachteile von Makros sind: 

1) Wiederholung der gleichen Befehls-Sequenzen 

2) Ein einzelner Makro kann eine Vielzahl von Befehlen bil¬ 
den 

3) Mangel an Standardisierung. 

4) Mögliche Einflüsse auf Register und Flags, die vielleicht nicht deutlich festge¬ 
legt sind. 


Ein Problem liegt darin, daß die in einem Makro verwende¬ 
ten Variablen nur innerhalb dessen bekannt sind [d.h. sie 
sind eher ■'lokal" anslall "global") Dies kann häufig zu einer 
Verwirrung führen, ohne das entsprechende Vorteile vor¬ 
handen sind Man sollte sich dieses Problem ständig bei 
der Verwendung von Makros vor Augen halten 1 . 


LOKAL- ODER 
GLOBAL¬ 
VARIABLE 
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KOMMENTARE 


ASSEMBLER-TYPEN 


Alle Assembler gestatten das Plazieren von Kommentaren in das Ouellpro- 
gramm. Kommentare haben keinen Einfluß auf den Objektcode, aber sie hei- 
fen beim Lesen, Verstehen und Dokumentieren des Programms. Gute Kom¬ 
mentare sind ein wesentlicher Teil beim Schreiben von Assemblersprachen¬ 
programmen. Ohne Kommentare sind Programme häufig sehr schwierig zu 
verstehen. 


Die richtige Anwendung von Kommentaren, zusammen mit 
der Dokumentation, sollen in einem spätem Kapitel be¬ 
schrieben werden, an dieser Stelle werden jedoch einige 
Richtlinien angegeben: 

1) Verwenden Sie Kommentare um auszudrücken, welche Anwendungs- 
Aufgabe das Programm ausführt, nicht wie der Mikrocomputer die Befehle 
ausführt 

Kommentare sollten etwa folgende Oinge angeben: "IST DIE TEMPERATUR 
OBERHALB DER GRENZE?". "ZEILEN-VORSCHUB ZUM FERNSCHREI¬ 
BER" oder "PRÜFE LADESCHALTER" 

Kommentare sollten folgende Dinge nicht ausdrücken. 

"ADDIERE 1 ZUM AKKUMULATOR", "SPRINGE ZUM START" oder "PRÜFE 
ÜBERTRAG". Man sollte beschreiben, wie das Programm das System 
beeinflußt Interne Einflüsse auf die CPU sind selten von Interesse 

2) Halten Sie Kommentare kurz und beschränken Sie sich auf das Wesent¬ 
liche Details sollten irgendwo anders in der Dokumentation zu finden sein. 

3) Kommentieren Sie alle Schlüsselpunkte. 

4) Kommentieren Sie nicht Standardbefehle oder Sequenzen, die Zähler und 
Zeiger ändern Achten Sie besonders auf Befehle, die keine offensichtliche 
Bedeutung besitzen kennten. 

5) Verwenden Sie keine obskuren Abkürzungen 

6 ) Machen Sie die Kommentare deutlich und lesbar. 

7) Kommentieren Sie alle Definitionen und beschreiben ihren Zweck Markie¬ 
ren Sie auch alle Tabellen und Datenspeicher-Bereiche. 

8 ) Kommentieren Sie Abschnitte des Programms, sowie individuelle Befehle 

9) Verwenden Sie möglichst eine gleichmäßige Terminologie Man kann (und 
sollte sogar) sich Wiederhofen Die Schönheit der Sprache ist nicht wesent¬ 
lich. 

10) Bringen Sie Anmerkungen bei Punkten an, die zur Verwirrung führen könn¬ 
ten. z.B. "ÜBERTRAG WURDE VOM LETZTEN BEFEHL GESETZT". Man 
kann diese in der endgültigen Dokumentation weglassen. 


KOMMENTIER¬ 

TECHNIKEN 


Obwohl alle Assembler dem gleichen Zweck dienen, variieren ihre Ausfüh¬ 
rungen in weitem Maße. Es soll nicht versucht werden, alle existierenden 
Typen von Assemblern zu beschreiben, Es sollen einfach die Ausdrücke defi¬ 
niert und erklärt werden. 


Ein Cross-Assembler ist ein Assembler, der auf einem an¬ 
deren Computer läuft, als auf jenem, für den er Program¬ 
me assembliert. 

Der Computer, auf dem der Cross-Assembler läuft, ist normalerweise ein großer 
Computer mit weitgehender Software-Unterstützung und schnellen Peripherie- 
Geräten, wie etwa eine IBM 360 oder 370, eine Univac 1108, oder eine 
Burroughs 6700. Der Computer, für den der Cross-Assembler Programme as¬ 
sembliert, ist normalerwise ein Mikroprozessor wie der 6502 oder 8080. Die 
meisten Cross-Assembler sind in FORTRAN geschrieben, so daß sie übettrag- 
bar sind 


Ein Selbst-Assembler oder residenter Assembler ist ein As¬ 
sembler, der auf dem Computer läuft, für den er Program¬ 
me assembliert 

Der Selbst-Assembler benötigt etliche Speicher und Peripheriegeräte, und er 
kann ziemlich langsam laufen. 

Ein Makro-Assembler ist ein Assembler, der die Definition 
von Sequenzen von Befehlen als Makros gestattet. Ein Mi¬ 
kro-Assembler oder Mikroprogramm-Assembler ist ein As¬ 
sembler, der zum Schreiben von Mikroprogrammen ver¬ 
wendet wird, die den Befehlssatz eines Computers definieren. Mikroprogram- 
mierung hat nichts speziell mit Mikrocomputern zu tun. 2 3 

Ein Meta-Assembler ist ein Assembler, der zahlreiche un¬ 
terschiedliche Befehlssätze handhaben kann. Der Anwen¬ 
der muß den speziellen verwendeten Befehlssatz definie¬ 
ren 

Ein One-Pass-Assembler ist ein Assembler, der das As- 
semblersprachen-Programm nur einmal durchläuft. Die 

wesentliche Schwierigkeit bei einem One-Pass-Assembler 
liegt im Vorhandensein eines Befehls, der sich auf eine Markierung bezieht, die 
später im Quellprogramm aufscheint. Ein One-Pass-Assembler muß irgendeine 
Möglichkeit besitzen, diese Vorwärts-Referenzen zu lösen. 


META¬ 

ASSEMBLER 


ONE-PASS- 

ASSEMBLER 


MAKRO¬ 

ASSEMBLER 


MIKRO¬ 

ASSEMBLER 


RESIDENTE 

ASSEMBLER 


CROSS- 

ASSEMBLER 


Ein gut dokumentiertes Programm ist leicht zu verwenden. Die hierfür aufge¬ 
wandte Zeit macht sich vielfach bezahlt. In den Programmbeispielen wird auf 
eine gute Kommentierung geachtet werden, obwohl für Lehrzwecke manchmal 
etwas uberkommentiert werden wird. 


Ein Two-Pass-Assembler ist ein Assembler, der das As- 
semblersprachen-Quellprogramm zweimal durchläuft. 

Beim ersten Mal sammelt und definiert der Assembler ein¬ 
fach alle Symbole. Das zweite Mal ersetzt er die Referenzen durch die tatsäch¬ 
lichen Definitionen. Der Zwei-Pass-Assembler hat keine Probleme mit Vor¬ 
wärts-Referenzen, kann jedoch etwas langsam sein, wenn kein schneller Mas¬ 
senspeicher (wie ein Floppy-Disk) zur Verfügung steht. Sonst muß der Assem¬ 
bler das Programm zweimal von einem langsamen Eingabe-Gerät (wie 
einem Lochstreifen-Leser eines Fernschreibers) lesen. Die meisten Assembler 
für Mikroprozessoren benötigen zwei Durchläufe. 


TWO-PASS- 

ASSEMBLER 
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FEHLER 


LADER 


Assembler besitzen normalerweise Fehler-Mitteilungen, die häufig aus einzel¬ 
nen codierten Buchstaben bestehen. Einige typische Fehler sind: 

• Undefinierte Namen (häufig ein orthografischer Fehler oder eine ver¬ 
gessene Definition). 

• Ungültige Zeichen (z.B. die Zahl 2 in einer Binärzahl). 

• Ungültiges Format (falsches Begrenzungszeichen oder unkorrekte 
Operanden). 

• Ungültiger Ausdruck (z.B. zwei Operanden in einer Zeile). 

• Ungültiger Wert(gewöhnlich zu groß). 

• Fehlender Operand 

• Doppelte Definition (d.h. zwei verschiedene Werte wurden dem glei¬ 
chen Namen zugewiesen). 

• Ungültige Markierung (z.B eine Markierung für eine Pseudo-Operation, 
die keine besitzend darf). 

• Fehlende Markierung 

• Undefinierter Operationscode. 

Bei der Interpretierung von Assembler-Fehlern muß man sich daran ennnern, 
daß der Assembler die falsche Spur verfolgen kann, wenn er einen vereinzelten 
Buchstaben, einen zusätzlichen Zwischenraum oder ein unkorrektes Satz¬ 
zeichen findet. Zahlreiche Assembler werden dann foitfahren, die folgenden Be¬ 
fehle falsch zu interpretieren und bedeutungslose Fehler-Mitteilungen liefern. Es 
muß immer der erste Fehler sorgfältig untersucht werden Darauf folgende kön¬ 
nen davon abhängen. Sorgfältige und ständige Verwendung von Standard- 
Formaten wird von vorneherein zahlreiche lästige Fehler vermeiden. 


Der Lader ist das Programm, das die Ausgabe (Objektcode) tatsächlich vom 
Assembler nimmt und in den Speicher plaziert. Lader reichen von sehr einfa¬ 
chen bis zu sehr komplexen Ausführungen. Es sollen einige wenige Arten be¬ 
schrieben werden. 


Ein Bootstrap-Lader (oder Urlader) ist ein Programm, das 
nur einige seiner ersten eigenen Befehle benützt, um den 
Rest selbst zu laden oder ein anderes Laderprogramm in 
den Speicher z u bringen. 

Der Urlader kann in einem ROM liegen, oder man muß ihn in den Computer¬ 
speicher durch Verwendung der Frontplalten-Schalter eingeben. Der Assem¬ 
bler kann einen Urlader an den Beginn des Objektprogrammes, das er er¬ 
zeugt, plazieren. 


Ein relokatibler (verschiebbarer) Lader kann Programme 
an jede beliebige Stelle in den Speicher stellen. Er lädt 
normalerweise jedes Programm in den Speicherraum, der 
unmittelbar nach dem vom vorhergehenden Programm 
verwendeten folgt. Die Programme müssen jedoch imstande sein, dies selbst 
durchzuführen, d.h. sie müssen relokatibel sein. Ein absoluter Lader wird da¬ 
gegen die Programme immer in den gleichen Speicherbereich legen). 


RELO¬ 

KATIBLER 

LADER 


BOOTSTRAP¬ 

LADER 


BINDE-LADER 


Ein Binde-Lader (linking loader) lädt Programme und Un¬ 
terprogramme getrennt. Er liefert Quer-Referenzen, d.h. 
ein Befehl in einem Programm oder Unterprogramm bezieht sich auf eine 
Markierung in einem anderen. Objektprogramme, die durch einen Binde-Lader 
geladen werden, müssen in einem Assembler erzeugt werden, der externe Refe¬ 
renzen gestattet. Eine andere Lösung besteht in der Trennung der Binde- und 
Ladefunktionen und Ausführungen des Verbindens milteis eines Programmes, 
das Link-Editor genannt wird. 
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Kapitel 3 

DER BEFEHLSSATZ DES 6502 IN 
ASSEMBLERSPRACHE 


Wir sind nun soweit, daß wir mit der Schaffung von Programmen in Assembler¬ 
sprache starten können. Wir beginnen in diesem Kapitel mit der Definition der 
individuellen Befehle des 6502 in Assemblersprache sowie mit den Syntaxre¬ 
geln des MOS-Technology-Assemblers. 

Es werden keinerlei Aspekte der Mikrocomputer-Hardware, Signale, Interfaces 
oder CPU-Archltektur in diesem Buch besprochen. Diese Informationen sind 
detailliert in dem Buch "An Introduction to Microcomputers: Volume 2- Some 
Real Microprocessors und Volume 3-Some Real Supp_ort Devices". 

In diesem Buch werden die Programmier-Techniken vom Standpunkt des Pro¬ 
grammierers in Assemblersprache betrachtet, wobei Anschlüsse und Signale 
völlig irrelevant sind und es keine wesentlichen Unterschiede zwischen einem 
Minicomputer und einem Mikrocomputer gibt. 

Unterbrechungen, direkter Speicherzugriff und die Stapel Architektur des 6502 
werden in späteren Kapiteln in diesem Buch beschrieben, in Verbincfung mit der 
Besprechung der Assemblersprachen Programmierung der gleichen Themen. 

Dieses Kapitel enthält eine ausführliche Definition jedes Befehls in Assembler¬ 
sprache. 

Der ausführlichen Beschreibung der individuellen Befehle gehl eine allgemeine 
Beschreibung des Befehlssatzes des 6502 voraus, wobei die Befehle in Grup¬ 
pen eingeteilt werden: Die allgemein verwendeten (Tabelle 3-2) und die selten 
verwendeten (Tabelle 3-3) Befehle. Wenn Sie bereits ein erfahrener Assembler- 
sprachen-Programmierer sind, ist diese Einteilung nicht besonders wichtig. Sind 
Sie jedoch ein Neuling in der Assemblersprachen-Programmierung. so ist es 
sehr empfehlenswert, mit dem Schreiben von Programmen nur unter Verwen¬ 
dung der "gebräuchlichsten" Befehle zu beginnen. Sobald Sie die Grundlagen 
der Assemblersprachen-Programmierung beherrschen, können Sie andere Be¬ 
fehle untersuchen und sie entsprechend einsetzen. 
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Tabelle 3-1. Häufig verwendete Befehle des 6502 


Tabelle 3-2. Gelegentlich verwendete Befehle des 6502 


Befehls¬ 

code 

Bedeutung 

ADC 

Add with Carry (Addiere mit Übertrag) 

AND 

Logical AND (UNDiere logisch) 

ASL 

Arithmetic Shift Left (Verschiebe arithmetisch nach links) 

BCC 

Branch if Carry Clear (Verzweige, wenn Übertrag gelöscht) 

BCS 

Branch if Carry Set (Verzweige, wenn Übertrag gesetzt) 

BEO 

Branch if Equal to Zero (Z = 1) (Verzweige, wenn gleich Null) 

BMI 

Branch if Minus (S= 1) (Verzweige, wenn Minus) 

BNE 

Branch if Not Equal to Zero (Z- 0) 

(Verzweige, wenn nicht gleich Null) 

BPL 

Branch if Plus (S=0) (Verzweige, wenn Plus) 

CMP 

Compare Accumulator to Memory 
(Vergleiche Akkumulator mit Speicher) 

DEC 

Decrement (by 1) (Dekrementiere um 1) 

DEX (DEY) 

Decrement Index Register X (Y) by 1 
(Dekrementiere Index-Register X(Y)um 1) 

INC 

Increment (by 1) (inkrementiere um 1) 

INX(INY) 

Increment Index Register X (Y) by 1 
(inkrementiere Index-Register X (Y) um 1) 

JMP 

Jump to New Location (Springe zu neuem Speicherplatz) 

JSR 

Jump to Subroutine (Springe zu Unterprogramm) 

LDA 

Load Accumulator (Lade Akkumulator) 

LDX (LDY) 

Load Index Register X (Y) (Lade Index-Register X (Y)) 

LSR 

Logical Shift Right (Verschiebe logisch nach rechts) 

PHA 

Push Accumulator onto Stack (Bringe Akkum. auf Stapel) 

PLA 

Pull Accumulator from Stack (Hole Akkum vom Stapel) 

ROL 

Rotate Left through Carry (Rotiere links durch Übertrag) 

ROR 

Rotate Right through Carry (Rotiere rechts durch Übertrag) 

RTS 

Return trom Subroutine (Kehre von Unterprogr. zurück) 

SBC 

Subtract with Borrow (Subtrahiere mit Borgen) 

STA 

Store Accumulator (Speichere Akkumulator) 

STX (STY) 

Store Index Register X (Y) (Speichere Index-Register X (Y)) 


Befehls¬ 

code 

Bedeutung 

BIT 

Bit Test (Bit-Test) 

BRK 

Break (Erzwinge Unterbrechung) 

CLC 

Clear Carry (Lösche Übertrag) 

CLD 

Clear Decimal Mode (Lösche Dezimai-Betriebsart) 

CLI 

Clear Interrupt Mask (Enable Interrupts) 

(Lösche Unterbrechungs-Maske (Gib Unterbrechungen frei)) 

CPX (CPY) 

Compare with Index Register X (Y) 

(Vergleiche mit Index-Register X (Y)) 

EOR 

Logical Exclusive-OR (Exklusiv-ODERiere logisch) 

NOP 

No Operation (Keine Operation) 

ORA 

Logical (Inclusive) OR (ODERiere logisch) 

RTi 

Return from Interrupt (Kehre von Unterbrechuni zurück) 

SEC 

Set Carry (Setze Übeilrag) 

SED 

Set Decimal Mode (Setze Dezimal-Betriebsart) 

SEI 

Set Interrupt Mask (Disable Interrupts) 

(Setze Unterbrechungs-Maske (Sperre Unterbrechungen)) 

TAX (TAY) 

Transfer Accumulator to Index Register X (Y) 

(Transferiere Akkumulator zum Index-Register X (Y)) 

TXA (TYA) 

Transfer Index Register X (Y) to Accumulator 
(Transferiere Index-Register X (Y) zum Akkumulator) 


Tabelle 3-3. Selten verwendete Befehle des 6502. 


Befehls¬ 

code 

Bedeutung 

BVC 

Branch if Overflow Clear 

(Verzweige, wenn Überlauf gelöscht) 

BVS 

Branch if Overflow Set (Verzweige, wenn Überlauf gesetzt) 

CLV 

Clear Overflow (Lösche Überlauf) 

PHP 

Push Status Register onto Stack 

(Bringe Status-Register zum Stapel) 

PLP 

Pull Status Register from Stack 

(Hole Status-Register von Stapel) 

TSX 

Transfer Stack Pointer to Index Register X 

(Transferiere Stapelzeiger zum Index-Register X) 

TXS 

Transfer Index Register X toStack Pointer 

(Transferiere Index Register X zum Stapelzeiger) 
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CPU-REGISTER UND STATUS-FLAGS 

Der Mikroprozessor 6502 besitzt einen Akkumulator, ein Status- (oderP-) Re¬ 
gister, zwei Indexregister, einen Stapelzeiger und einen Befehlszähler. Diese 
Register können wie folgt dargestellt werden; 


Der kürzere Stapelzeiger des 6502 besitzt keine besondere Bedeutung, wenn 
Sie diese CPU als selbständiges Produkt verwenden. Ein Stapel mit 256 Bytes 
ist gewöhnlich ausreichend lür jede typische Mikrocomputer-Anwendung. Und 
seine Lage im unteren Speicher bedeutet einfach, daß die niedrigen Speicher- 
Adressen als Lese/Schreib-Speicher eingerichtet werden müssen. 


Akkumulator A 
Index-Register X 
Index-Register Y 

Befehlszähler PC {Prpgram C*unler) 
Stapelzeiger $p (Stack Pointer} 
Status-Register P 


Das Statusregister des 6502 enthält sechs Status-Flags und ein Unterbre¬ 
chungs-Steuerbit. Die sechs Status-Flags lauten; 


Carry(C) 

Zero (Z) 
Overflow(V) 
Negativ (N) 
•ecimal Mode (D) 
Break (B) 


= Übertrags-Flag 
= Nuii-Fiag 
= Überlauf-Fiag 
= Negativ-Fiag (Vorzeichen) 
= Dezimale Betriebsart 
- Unterbrechung 


Die Status werden bestimmten Bit-Positionen innerhalb des Statusregisters wie 
folgt zugeordnet: 

7 6 5 4 3 2 1 0 Bit-Nummer 

|N |v | 1 B ID | I 1Z | C | ^ 6502-Status-RegisterP 


Der Akkumulator (A) ist ein primärer Akkumulator, wie er in "Einführung in die 
Mikroprozessor-Technik" beschrieben wurde. 

Die Indexregister (X und Y) sind nur acht Bits lang, und somit anders als die ty¬ 
pischen Mikrocomputer-Indexregister, wie sie in "Einführung in die Mikrocom¬ 
puter-Technik" beschrieben sind. Sie ähneln mehr den klassischen Computer- 
Indexregistern, wie sie zur Aufbewahrung von Indizes, kurzen Versetzungen 
oder Zählern verwendet werden. 

Der 6502 besitzt einen Stapel, der im Speicher eingerichtet und mittels des Sta¬ 
pelzeigers indiziert wird, wie in dem bereits erwähnten Buch beschrieben ist. 

Der einzige Unterschied gegenüber diesen Beschreibungen besteht darin, daß 
der Stapelzeiger des 6502 nur acht Bit breit ist, was bedeutet, daß die maxi¬ 
male Stapellänge 256 Bytes beträgt. Die CPU setzt immer 01 16 als das höher¬ 
wertige Byte jeder Stapel-Adresse ein, was bedeutet, daß die Speicherplätze 
0100,6 bis 01 FF,6 ständig dem Stapel zugewiesen werden: 

oi I xx Isp 

♦ —T— 

•f ^ 

I 

Olxx ist die Staüel-Adresse 


Der Befehlszähler des 6502 ist ein typischer Befehlszähler, wie er in der 
"Einführung in die Mikrocomputer-Technik” beschrieben wird. 

Das Übertrags-Flag (Carry flag) bewahrt die Überträge des höchstwertigen 
Bits in jeder arithmetischen Operation auf. Das Übertrags-Flag ist auch in den 
Schiebe- und Rotations Befehlen enthalten. Die einzige ungewöhnliche Eigen¬ 
schaft des Übertrags-Flags des 6502 besteht darin, daß es eine entgegenge¬ 
setzte Bedeutung in Subtraktions-Operationen besitzt. Nach einem SBC Befehl 
wird der Übertrag gelöscht, wenn ein »Borgen« erforderlich war und gesetzt, 
wenn kein Borgen nötig war Beachten Sie auch, daß der SBC-Befehl (Subtract 
with Carry) resultiert in (A) »(A) - (M) - (1 - C), wobei M der andere Operand ist. 
Diese Verwendung ist anders als bei den meisten Mikroprozessoren oder Com¬ 
putern jüngster Herkunft, und der Anwender sollte dies beachten. 

Das Nuil-Statusflag (Zero) ist Standard. Es wird auf 1 gesetzt, wenn irgendeine 
arithmetische oder logische Operation ein Resultat mit dem Wert 0 erzeugt. Es 
wird auf 0 gesetzt, wenn irgendeine arithmetische oder logische Operation ein 
Ergebnis verschieden von Null erzeugt. 

Das Negativ-Statusflag (Negative) ist Standard. Es wird den Wert des hochwer¬ 
tigen (Vorzeichen ) Bits jedes arithmetischen oder logischen Resultats anneh¬ 
men. Daher identifiziert ein Negativ-Statuswert von 1 ein negatives Ergebnis, 
und ein Negativ-Wert von 0 zeigt ein positives Ergebnis an. Das Negativ-Status¬ 
zeichen wird gesetzt oder gelöscht unter der Annahme, daß Sie binäre Arithme¬ 
tik mit Vorzeichen verwenden. Wenn Sie keine Arithmetik mit Vorzeichen ver¬ 
wenden, können Sie den Negativ-Status ignorieren, oder Sie können ihn zur 
Identifizierung des Wertes des hochwertigen Bits des Ergebnisses einsetzen. 

Das Dezimalbetriebs-Flag veranlaßt, wenn es gesetzt ist, die Befehle 
Add-with-Carry (Addiere mit Übertrag) und Subtract-with-Carry (Subtrahiere 
mit Übertrag) zur Ausführung von BCD-Operationen. Wenn daher der Dezimal- 

Betriebs-Status gesetzt ist und ein Add-with-Carry- oder Subtract-with-Carry-Be- 
fehl ausgeführt wurde, nimmt die CPU an, daß beide ursprünglichen B-Bit-Werte 
gültige BCD-Zahlen sind und das erzeugte Ergebnis ebenso eine gültige BCD- 
Zahl sein wird. Da die CPU des 65f2 dezimale Addition und Subtraktion aus¬ 
führt, besteht kein Bedarf nach einem Halb-Übertrags- oder Zwischen-Status 
(Halt-Carry Status). Dieser Status ist in "Einführung in die Mikrocomputer-Tech¬ 
nik" beschrieben. Ein Problem beim 6502 besteht darin, daß die gleiche Be¬ 
fehls-Sequenz verschiedene Resultate ergeben wird, abhängig davon, ob der 
Dezimalbetriebs-Status gesetzt oder gelöscht war. Daher können Verwirrung 
und Fehler auttreten, wenn das Dezimalbetriebs-Fiag zufällig einen falschen 
Wert erhalten hat. 

Der Break-Status gehört zu den Software-Unterbrechungen. Wenn eine Soft¬ 
ware-Unterbrechung (BRK-Befehl) ausgeführt wird, wird die CPU-Logik des 
6502 das Break-Statusflag setzen. 

I ist ein Standard-Haupt-Unterbrechungs-Freigabe/Sperr- oder Unterbre- 
chungsmasken-Flag. Wenn I gleich 1 ist, werden die Unterbrechungen ge¬ 
sperrt. Ist I gleich 0, werden Unterbrechungen freigegeben. 
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Der Überlauf-Status (Overflow) ist ein typischer Überlauf mit Ausnahme, daß 
er als Steuer-Eingang eines 6502-Mikroprozessors verwendet werden kann. 

Ennnern Sie sich daran, daß bei Verwendung von Binär-Arithmetik der Überlauf- 
Status ein Ergebnis einer Größe anzeigt, die zu groß zur Darstellung in einer ge¬ 
gebenen Wortgröße ist. Der Überlaui-Status wurde detailliert in "Eintührun in 
die Mikrocom uter-Technik” besprochen. Er gleicht dem Exklusiv-ODER von 
Überträgen aus den Bits 6 und 7 während arithmetischer Operationen. Der Mi¬ 
kroprozessor 6502 gestattet externer Logik das Setzen des Überlauf-Status und 
kann in diesem Fall anschließend als allgemeiner Logik-Indikator verwendet 
werden. Sie müssen sehr sorgfältig vorgehen, wenn Sie den Uberlauf-Status auf 
diese Weise verwenden, da das gleiche Status-Fiag durch arithmetische Befehle 
modifiziert wird. Sie als Programmierer müssen dafür sorgen, daß ein Befehl, 
der den Überlauf-Status modifiziert, nicht in der Zeit ausgeführt wird, in der ex¬ 
terne Logik diesen Status setzt und die Programmlogik ihn hierauf testet. 


Die Literatur des 6502 bezeichnet das Vorzeichen-Bit als 
Negativ-Bit mit dem Symbol N. In dem bereits erwähnten 
Buch “Einführung in die Mikrocomputer-Technik“ wird 
dagegen als Standardsymbol für das Vorzeichen das Zeichen S (Sign bit) ver¬ 
wendet. In diesem Buch werden wir wir jedoch die allgemein eingeführte Be¬ 
zeichnung N verwenden. 


UNTERSCHIEDE 
IN DER 

SCHREIBWEISE 


SPEICHER-ADRESSIERUNGSARTEN DES 6502 

Der 6502 bietet elf grundlegende Adressier-Arten: 

1) Speicher - unmittelbar 

2) Speicher - absolut oder direkt, Nicht-Null-Seite (non-zero page) 

3) Speicher-Nullseite (direkt) 

4) Impliziert oder inhärent 

5) Akkumulator 

6) Vor-indiziert indirekt 

7) Nach-indiziert indirekt 

8) Nullseite, indiziert (auch Basis-Seite, indiziert, genannt) 

9) Absolut indiziert 

10) Relativ 

11) Indirekt 

Es gibt wesentliche Variationen in den Ausdrücken, welche Methoden mit wel¬ 
chen Befehlen zulässig sind. Siehe Tabelle 3-4 für die mit jedem Befehl verfüg¬ 
baren Adressier Optionen. 


Speicher - Unmittelbar 

Bei dieser Form der Adressierung liegt einer der Operanden in dem Byte vor. 
das unmittelbar dem Byte des Objektcodes folgt Ein unmittelbarer Operand 
wird durch Vorsetzen des Symbols # vor dem Operanden spezifiziert. Zum Bei¬ 
spiel fordert 


AND #$08 

den Assembler auf, einen Befehl zu erzeugen, der den Wert von 00, s mit dem 
Inhalt des Akkumulators logisch ÜNDieren wird. 


Daten- 



i Byte 



7 6 5 4 3 2 1 0 


□EinoDOEia 


*$08 



7 6 5 * 3 2 ’ 0 
2. Byle RcToT ol 1 l 3 To~fo) 


Diese Bils wählen die 
AND-OperahOn 


Diese Bits wählen 
unmittelbare Adressierung 
mit einem #peranden in in A 
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Speicher - direkt 

Diese Art der Adressierung verwendet das zweite - oder zweite und dritte (wenn 
nicht auf der Null- oder Basis-Seite) - Byte des Befehls zur Identifizierung der 
Adresse eines Operanden im Speicher Die Nullseiten Version wird spezifiert, 
wenn der im Befehl als Operand verwendete Ausdruck auf einen Wert zwischen 
00 1S und FFis zuruckgeht Zum Beispiel 


Die Nicht-Null-Seiten- (absolute) Version ist ähnlich, mit der Ausnahme, daß die 
Adresse des Operanden zwei Bytes belegt Zum Beispiel 

AND $31F6 

forder: den Assembler auf, einen UND-Befehl zu erzeugen, der den Wert im 
Speicherplatz 0030, s mit dem Inhalt des Akkumulators logisch UNDiert. 


AND $30 

fordert den Assembler auf. einen UND-Befehl zu erzeugen, der den Wert im 
Speicherplatz 0030« mit dem Inhalt des Akkumulators logisch UNDiert. 


Daten- 



Daten- 



31*6 


rrvrvTtm 
mmmm ♦ 
mininni ♦ 
mmmm ♦ 


1 

2 

3 


Sie sollten beachten, daß 16-Bit Adressen mit den acht 
höchstwertigen Bits zuerst (bei der niedrigeren Adresse) 
gespeichert werden, gefolgt von den acht höchstwertigen 
Bits (in der höheren Adresse). Dies ist das gleiche Verfahren, wie es bei den 
Mikroprozessoren 8080, 8085 und Z80 verwendet wird, jedoch entgegengesetzt 
dem beim Mikroprozessor 6800 verwendeten Verfahren 


SPEICHEBN von 
ADRESSEN 


Implizierte oder inhärente Adressierung 

Diese Betnebsart bedeutet, daß keine Adressen zur Ausführung des Befehls er¬ 
forderlich sind. Typische Beispiele inhärenter Adressierung sind CLC (Clear 
Carry) und TAX (Transferiere Register A zu Register X) 


Akkumulator-Adressierung 

Diese Betnebsart bedeutet, daß der Befahl die Daten im Akkumulator verarbei¬ 
tet Beim Mikroprozessor 6502 sind die einzigen Akkumulator-Befehle die Ver¬ 
schiebungen ASL (Arithmetische Links-Verschiebung). LSR (Logische Rechts¬ 
verschiebung), ROL (Rotiere links durch Übertrag) und ROR (Rotiere rechts 
durch Übertrag) 
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Vor-indizierte indirekte Adressierung 


Nach-indizierte indirekte Adressierung 


Diese Betriebsart bedeutet, daß das zweite Byte des Befehls zum Inhalt des 
X-Indexregisters zum Zugriff auf einen Speicherplatz in den ersten 256 Bytes 
des Speichers addiert wird, wodurch die indirekte Adresse gefunden wird Hier 
wird eine Addition verwendet, bei der jeder Übertrag, der bei einer Adressen- 
Addition gebildet wird, gelischt wird. Zum Beispiel 

AND ($2*,X) 

fordert den Assembler auf. einen Befehl zu erzeugen, der den Inhalt des Akku¬ 
mulators mit dem Inhalt des Bytes, das durch den Speicherplatz auf der Nullsei¬ 
te adressiert wird, der durch die Summe von 20, 6 und dem Inhalt des Indexregi¬ 
sters gegeben ist, logisch UNDiert. Beachten Sie die Verwendung der Klammern 
im Adressenfeld zur Anzeige von "Inhalt von". 


Daten- 



OOrr+20 
0 rr*21 


ppqq 


mm mm 
mmmm ♦ 
mmmm + 


t 

2 


Erinnern Sie sich daran, daß der Übertrag aus der Adressen-Addition ignoriert 
wird, das heißt, die Adresse des ersten Adressen-Bytes ist ein Zahl in Mod 256, 
Beachten Sie, daß die indirekte Adresse mit ihren niedrigstwertigen Bits zuerst 
(bei der niedrigeren Adresse) gespeichert wird. Beachten Sie auch, daß die 
Adresse zwei Speicher-Bytes belegt. 

Nur das X-Indexregister kann für vor-indizierte indirekte Adressierung verwen¬ 
det werden. 


Dieses Verfahren bedeutet, daß das zweite Byte des Befehls eine Adresse in 
den ersten 256 Speicherbytes enthält Diese Adresse und der nächste Speicher¬ 
platz enthalten eine Adresse, die zum Inhalt des Y-Indexregisters zur Erlangung 
der effektiven Adresse addiert wird. 

Beachten Sie die Unterschiede zwischen diesem Verfahren und der vor-indi- 
zierten indirekten Adressierung 

1) Bei vor-indizierter indirekter Adressierung wird die Indizierung vor der Adres¬ 
sierung ausgeführt, während bei der nach-indizierten Adressierung die 
Adressierung vorder Indizierung ausgeführt wird, 

2) Vor-indizierte indirekte Adressierung verwendet das X-Indexregister, wäh¬ 
rend nach-indizierte indirekte Adressierung das Y-Indexregister verwendet 

3) Vor-indizierte indirekte Adressierung ist nützlich bei der Auswahl eines Sat¬ 
zes von indirekt zu verwendenden Adressen, während nach-indizierte indi¬ 
rekte Adressierung für den Zugriff auf Elemente in einem Feld oder einer Ta¬ 
belle geeignet ist, für die die Basis-Adresse indirekt erhalten worden ist. 

Ein Beispiel für nach-indizierte indirekte Adressierung ist 

AND ($20),Y 

welches den Assembler auffordert, einen Befehl zu erzeugen, der den Inhalt 
des Akkumulators mit dem Inhalt des Bytes, adressiert durch Addition des 
Y-Indexregisters zur Adresse im Speicherplatz 002* 16 , logisch UNDieren wird. 
Beachten Sie. daß hier nur $20 innerhalb der Klammern steht, da nur dieser 
Teil der Adresse indirekt verwendet wird. 


p 


A 

x 

Y 

SP 

PC 


Datsn- 



Hier wird wiederum die indirekte Adresse mit ihrem niedrigstwertigen Byte 
zuerst (bei der niedrigeren Adresse) gespeichert. Anders als bei der vor-indi- 
zierten Adressierung ist diese Adressen-Addition eine volle 1 6-Bit-Addition Je¬ 
doch wird jeder Übertrag von Bit 15 ignoriert. Es kann nur das Y-Indexregister 
mit nach-indizierter, indirekter Adressierung verwendet werden. 


3-10 


3-11 






Indizierte Adressierung 


Dalen- 

Sooclier 


Diese Art der Adressierung verwendet das zweite- oder zweite und dntte (wenn 
nicht aut der Nullseite) - Byte des Befehls zur Spezifizierung der Basis-Adresse 
Diese Basis-Adresse wird dann zum Inha't des Indexregisters X oder Y addiert, 
um die effektive Adresse zu erhalten, X und Y sind nicht austauschbar, da keine 
Befehle beide Formen der einfachen Indizierung mit sowohl X als auch Y besit¬ 
zen In der Tat ist der einzige Befehl, der eine Nuflseiten-Indizierung mit Y ge¬ 
stattet, der Befehl LDX {Load Index Register X) und STX { Store Index Register 
X). Sie sollten sich auf die Tabelle 3-4 beziehen, um zu bestimmen, welche 
Adressier-Optionen bei Ihrem Befehl verfügbar sind. 

Ein typisches Beispiel indizierter Nullseiten Adressierung ist 

AND $20,X 

Hierdurch wird der Assembler aufgefordert, den Befehl zu bilden, der den Inhalt 
des Akkumulators mit dem Inhalt des Bytes an der Adresse, gegeben durch die 
Summe von 20i« und dem Inhalt des X-Indexregisters, logisch UNDiert Dies ist 
ein 2-Byte-Befehl. da die Adresse innerhalb der ersten 256 Bytes des Speichers 
llegl. Beachten Sie, daß es keine 2-Byte-Form von AND $20,X gibt, obwohl 
eine allgemeinere 3-Byte-Form dieses Befehls existiert 


Daten- 



00204fr 


rrrnrnm 
rr> m=rvT5 + 1 
rrwnmm ♦ 2 



Hier kann das Indexregister X als auch das Indexregister Y verwendet werden. 
Jedoch einige Befehle {wie etwa ASL, DEC, INC, LSR. ROL und ROR) gestatten 
nur das Indexregister in dieser Betriebsart. Dies ist auch (mehr logisch) mit dem 
Befehl LDY (Load Index Register Y) und STY (Store Index Register Y) der Fall 


Ein typisches Beispiel absoluter indizierter Adressierung ist 

AND $31FE,Y 

welches den Assembler auffordert, den Befehl zu erzeugen, der den Inhalt des 
Akkumulators mit dem Inhalt des Bytes bei der Adresse, die durch die Summe 
von 31 FE,s und dem Inhalt des Y-Indexregisters gegeben ist, logisch UNDieren 
wird. Dies ist ein 3-Byte Befehl, da die Basis-Adresse nicht innerhalb der ersten 
256 Bytes des Speichers liegt. 
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Indirekte Adressierung 

Indirekte Adressierung ist nur bei dem Befehl JMP (Jump to New Location - 
Springe zu neuem Speicherplatz) möglich. Hierbei enthält das zweite und dntte 
Byte des Befehls die Adresse, bei der die effektive Adresse liegt. Beachten Sie, 
daß die indirekte Adresse jeden beliebigen Wert besitzen und überall im Spei¬ 
cher liegen kann. Offensichtlich kann diese Adressier Art als ein spezieller Fall 
entweder der nach-indizierten indirekten Adressierung oder vor-indizierten indi¬ 
rekten Adressierung angesehen werden, bei der das Indexregister null enthält. 
Ein typisches Beispiel ist: 


Relative Adressierung 

Befehle für bedingte Verzweigungen verwenden programmabhängige Adressie¬ 
rung. Eine Einzelbyte-Versetzung wird als Binärzahl mit Vorzeichen behandelt, 
die zum Befehlszähler addiert wird, nachdem der Inhalt des Befehlszählers in- 
krementiert wurde, um den nächstfolgenden Befehl zu adressieren. Dies gestat¬ 
tet Versetzungen im Bereich von +1 29, a bis -126,o Bytes. Ein typisches Beispiel 
ist 

BCC *+5 


JMP (S31FE) 

das den Assembler auffordert, einen JMP-Befehl zu bilden, der den Befehlszäh¬ 
ler von dem Speicherplatz lädt, der durch den Inhalt der Speicherplätze 31 FEt & 
und 31 FF,s adressiert wird. Erinnern Sie sich daran, daß absolute Adressen 16 
Bits lang sind und zwei Speicherbytes belegen. Die an einer Adresse liegenden 
Daten sind jedoch 8 Bits lang. Dieses Durcheinander betrifft alle 8-Bit-Prozes- 
soren, stellt jedoch ein besonderes Problem beim 6502 infolge seiner zahlrei¬ 
chen indirekten und indizierten Adressierungsarten dar. Indirekte Adressierung 
wird ausführlicher in "Einführung in die Mikrocomi uter-Te chnik" . Kapitel 6, be¬ 
schrieben Erinnern Sie sich daran, daß alle Adressen mit ihrem niedrigstwerti¬ 
gen Byte zuerst (bei der niedrigeren Adresse) gespeichert werden. 


Daten- 



31 FE 
31 FF 


jiwiifnm 
mmmm ♦ 
rnmmm ► 


1 

2 


Der endgültige Wert des Befehlszählers ist ppqq. 


welches den Assembler auffordert, einen Befehl BCC (Branch on Carry Clear. 
d.h. Verzweigung wenn Übertrag = 0) zu erzeugen, der den Befehlszähler mit 
seinem momentanen Wert plus fünf laden wird, wenn der Übertrag in Wirklich¬ 
keit Null ist. Wenn der Übertrag Eins ist, so führt der Befehl nichts aus. Beachten 
Sie, daß der Befehl selbst zwei Speicherbytes belegt und die Versetzung ab 
dem Ende des Befehls gemessen wird Daher sollte die Versetzung 3 sein, um 
eine Verzweigung zum Speicherplatz fünl. gerechnet ab dem einen, in dem das 
erste Byte des Befehls liegt, zu bewirken. Beachten Sie, daß das Symbol * für 
den momentanen Wert des Befehlszählers verwendet wird (in Wirklichkeit der 
Stellenzähler des Assemblers wie in Kapitel 2 beschrieben). 

Die Ausführung des Befehls BCC‘+5 kann wie nachstehend dargestellt be¬ 
schrieben werden. Beachten Sie. daß der gesamte Befehl vom Speicher geholt 
wird, bevor die Bestimmungsadresse berechnet wird. Beachten Sie auch, daß 
es keine anderen verfügbaren Adressier-Arten bei Befehlen für bedingte Adres¬ 
sierung gibt. 


n v B o i z c 

p p i 111 n 


Daten¬ 

speicher 
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BEFEHLSSATZ DES 6502 


Symbole in der mit STATUS bezeichneten Spalte: 


Befehle erschrecken häufig Mikrocomputer-Anwender, die Neulinge in der 
Programmierung sind. Nimmt man die Befehle als getrennten Vorgang an, so 
sind die mit der Ausführung eines einzelnen Befehls verbundenen Operationen 
einfach zu überblicken. Der Zweck dieses Kapitels bestehtim Trennen und Er¬ 
klären von Operationen. 

Weshalb nennt man die Befehle eines Mikrocomputers einen "Befehlssatz"? Der 
Grund hierfür ist, daß die Befehle vom Entwickler eines Mikrocomputers sehr 
sorgfältig ausgewählt wurden. Sie müssen auf einfache Weise komplexe Opera¬ 
tionen als eine Folge einfacher Vorgänge ausführen, von denen jeder durch 
einen Befehl eines gut durchdachten "Befehlssatzes" dargestellt wird. 

In Übereinstimmung mit "An Introduction to Microcomputers: Volume 2" zeigt 
die Tabelle 3-4 den Befehlssatz des Mikrocomputers 6502, wobei ähnliche 
Befehle in Gruppen zusammengefaßt sind. Individuelle Befehle werden in 
alphabetischer Reihenfolge des Objektcodes in Tabelle 3-5 aufgelistet und 
eine alphabetische Reihenfolge der Befehls-Mnemoniks in Tabelle 3-6. Tabelle 
3-6 vergleicht auch den Befehlssatz des 6800 mit dem des 6502 Wir werden 
den 68t0 und 65*2 später in diesem Kapitel besprechen, nachdem wir uns ein¬ 
gehend mit dem Befehlssatz des 6502 befaßt haben. 

Zusätzlich zur Feststellung, was jeder Befehl ausführt, wird in den Besprechun¬ 
gen der individuellen Befehle der Zweck des Befehls innerhalb der normalen 
Programmlogik erklärt. 


ABKÜRZUNGEN 


Folgende Abkürzungen werden in diesem Kapitel verwendet: 


Die Register: 

A 

X 

V 

PC 

SP 

p 


Akkumulator 
Indexregister X 
Indexregister Y 

Befehlszähler {Program Counter) 

Stapelzeiger (Stack Pointer) 

Statusregister, wobei die Bits folgendermaßen zugeordnet 
sind: 

7 6 5 4- 3 2 1 ^ Sif-Nurrmer 

In | V |B |p | I Iz Icl - ^ - Status-ReS'sler (p) 

R«servierl für Erweiterung 
(derzeit nicht verwendet) 


Status (Fiags): 


N 

V 

B 

D 

I 

Z 

c 


Negativ-Status (Negativ- oder Vorzeichen-Status) 
Overflow-Status (Überlauf-Status) 

Break-Status 

Decimal-Mode-Status (Dezimai-Betriebsart-Status) 
Interrupt-Disable-Status (Unterbrechungs-Sperr-Status) 
Zero-Status (Null-Status) 

Carry-Status (Übertrags-Status) 


(leer) 

X 

0 

1 

6 

7 

addr 

(addr+1 ,addr] 


addrl 6 

data 

disp 

labei 

PC(HI) 

PC(LO) 

PP 

qq 

[] 


[[]] 


A 

V 

-V- 


Operation beeinflußt das Flag nicht 
Operation beeinflußt Flag 
Operation löscht Flag 
Operation setzt Flag 

Operation gibt Bit 6 des Speicherplatzes wieder 

Operation gibt Bit 7 des Speicherplatzes wieder 

8 Bits der absoluten oder Basis-Adresse 

Die Adresse, gebildet aus dem Inhalt der Speicherplätze 

addr und addr+1. Diese Adresse wird bei der nach-indizierten 

indirekten Adressierung verwendet. 

16 Bits einer absoluten oder Basis-Adresse 
8 Bits unmittelbarer Daten 

Eine 8-Bit-Adressenversetzung (displacement) mit Vorzei¬ 
chen 

Absolute Adresse mit 1 6 Bits, Ziel eines Befehls "Springe" 
oder "Springe zu Unterprogramm 1 ’ 

Die hochwertigen 8 Bits des Befehlszählers 
(Program Counter) 

Die niederwertigen 8 Bits des Befehlszählers 

Das zweite Byte eines Befehlscodes eines Zwei- oder 

Drei-Byte-Befehls 

Das dritte Byte eines Drei-Byte-Objektcodes 
Inhalt des Speicherplatzes, der mit eckigen Klammern einge¬ 
schlossen ist Beispielsweise stellt |FFFE] den Inhalt des 
Speicherplatzes FFFE I6 dar. (addr 16+-X] stellt den Inhalt des 
Speicherplatzes dar, der durch Addition des Inhalts des Regi¬ 
sters X zu addr16 adressiert wird, (SP) stellt den Wert an der 
Spitze des Stapels dar (Inhalt des Speicherplatzes, adressiert 
durch den Stapelzeiger) 

Indirekte Adressierung: Der Inhalt des Speicherbytes, adres¬ 
siert durch den Inhalt des innerhalb der eckigen Klammer an¬ 
gegebenen Speicherplatzes. Zum Beispiel stellt ([addr+X]] 
den Inhalt eines Speicherplatzes dar, der über die vor¬ 
indizierte indirekte Adressierung adressiert wurde. 

Addition - entweder Binär-Addition ohne Vorzeichen oder 
BCD-Addition, abhängig vom Zustand des Dezimal-Betriebs- 
arts-Status. 

Binäre oder BCD-Subtraktion, ausgeführt durch Addition des 
Zweierkomplements des Subtrahenden zum Minuenden. 

Das Einerkomplement der unter dem Strich angegebenen 
Größe. Zum Beispiel stellt A das Komplement des Inhalts des 
Akkumulators dar. C stellt das Komplement des Wertes des 
Übertrags-Status (Carry-Status) dar. 

Logisch UND 
Logisch ODER 
Logisch Exklusiv-ODER 

Daten werden in der Richtung des Pfeiles transferiert. 
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BEFEHLS-MNEMONIKS 


STATUS 


Tabelle 3-4 faßt den Befehlssatz des 6502 zusammen. Die BEFEHLS-Spalte 
zeigt die Befehls-Mnemoniks (LDA, STA, CLC) und die Operanden, falls welche 
voriiegen, die mit dem Befehls-Mnemonik verwendet werden. 

Der feste Teil des Assemblersprachen-Befehls wird in GROSSBUCHSTABEN 
dargestellt. Der variable Teil (unmittelbare Daten, Adresse oder Markierung) 
wird in Kleinbuchstaben gezeigt. 

Wenn ein Mnemonik mehr als eine Art eines Operanden hat, wird jede Art sepa¬ 
rat ohne Wiederholung des Mnemonik aufgelistet. Einige Beispiele sehen fol¬ 
gendermaßen aus; 

STX 

addr 

addr.Y 

addr16 

wird zu; STX $75 
STX $60 Y 
STX $4276 


BEFEHLS-OBJEKTCODES 

Für Befehlsbytes ohne Variationen werden die Objektcodes als zwei hexadezi¬ 
male Ziffern dargestellt (z.B. 8A). Für Befehlsbytes mit Variationen wird der 
Objektcode mit acht Binärziffern dargestellt (z.B. lOlaaaOI). 

Der Objektcode und die Befehlslänge in Bytes sind in Tabelle 3-4 für Jede Be¬ 
fehls-Variante gezeigt. Tabelle 3-5 listet den Objektcode in numerische Ord¬ 
nung auf, und Tabelle 3-6 zeigt die entsprechenden Objektcodes für die Mne- 
moniks, aufgezählt in alphabetischer Reihenfolge. 


Die Status-Flags sind im Statusregister (P) wie folgt gespeichert; 



Bil-Nummer 

Status-Register 


Übertrags-Status (Uberlreg aus Bit 7) 

Null-Status (1 für null. 0 für mcht-nutl) 
Unterbrechungs-Sperr-Status 

|1 bedeutet.daß Unterbrechungen gesperr: sind) 
Desifrial-Betriebs-Status (1 für Dezimal-Betrieb) 
Break-Status (1 bedeutet, daß ein Break-Befebt 
ausgefuhr worden ist} 

Dieses Bit wird nicbt verwendet 
Uberiaul-Status 

Nagativ-Status (Vorzeichen. Wert von Bit 7) 


Bei der Beschreibung der individuellen Befehle wird der Einfluß der Befehls- 
Ausführung auf die Status wie folgt gezeigt: 


N V D I Z C 



Modiifiztert, um Ergebnis der Ausführung wiedeizugeben 
Unverändert 

Ohne Bedingung auf 0 zuiuckgesetzt 
Ohne Bedingung auf 1 gesetzt 
Bit 6 des getesteten Bytes 
Bit 7 des getesteten Bytes 


BEFEHLS-AUSFÜHRUNGSZEITEN 

Tabelle 3-4 listet die Befehls-Ausführungszeiten in Anzahl der Taktperioden 

auf. Die tatsächliche Auslührungszeit kann durch Dividieren der gegebenen 
Zahl der Taktperioden durch die Taktgeschwindigkeit ermittelt werden. Bei¬ 
spielsweise ergibt sich für einen Befehl, der fünf Taktperioden benötigt, bei 
einem 2MHz-Takt eine Ausführungszeit von 2 5 Mikrosekunden. 


Ein X zeigt einen Status an. der gesetzt oder ge¬ 
löscht wird. Ein 0 identifiziert einen Status, der 
immer gelöscht wird. Eine 1 identifiziert einen 
Status, der immer gesetzt wird. Eine leere Stelle 
bedeutet, daß der Status nicht geändert wird. Die 
Zahlen 7 und 6 zeigen, daß das Flag den 
Wert von Bit 7 oder Bit 6 des Bytes enthält, das 
durch den Befehl getestet wird. 


STATUS¬ 
ÄNDERUNGEN 
BEI BEFEHLS¬ 
AUSFÜHRUNG 
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Tabelle 3-4. Eire Zusammenfassung des 6502-Befehlssatzes 


ro 

o 


Typ 


Befehl 

Objekt-Code 

Byte 

Takt- 

Perio¬ 

den 

Status 

Ausgefiihrte Operalion 

N 

V 

D 

1 

z 

c 

LDA 










Lade Akkumulator vom Speicher 



A5 »p 

2 

3 

X 




X 


A—[addr| 

Null-Sene direkt 


B5 pp 

2 

4 

X 




X 


A*-[addr»-X| 

Nuii-Seile indiziert 

{addr.X] 

Alpp 

2 

6 

X 




X 


A—[[addr+-XJl 

Vor-mdizierimdirekl 

(addr).Y 

Bl pp 

2 

S" 

X 




X 


A«—[[addr+i.addr]+Y] 

Nach-mdizieri indirekt 


Ai ppqq 

3 

4 

X 




X 


A«—[addr16] 

Erweilerl direkt 

addrt6,X od. Y 

11011x0) pPQ« 

3 

4* 

X 




X 


A«—|addr16+X| oder A*—laddrli+Y] 

Absolut indiziert 

STA 










Speichere Akkumulator in Speicher 



85 pp 

2 

3 







[addr]«—A 

fsJuii-Seite di/eki 


S5 KP 

2 

4 







[addr+X]«—A 

Nuii-Seile indiziert 


61 PP 

2 

6 







|(a<Jdf+X[]^A 

Yor-mdizieriindireki 

(addr).Y 

91 pp 

2 

6 







liaddr+l.addrl+Y]—A 

Nach-mdizierl indirekt 

addi6 

6D ppdq 

3 

4 







|addri6]«-A 

Erweitert direkl 

addrl 6.X od. Y 

10011x01 PPCJQ 

3 

5 







(addrl6-«-X)*-A oder [addrl6+Y)*-A 

Absolul indiziert 

LDX 










Lade Index-Register X vem Speicher. 

Index nur über Register Y 


A6 pp 

2 

3 

X 




X 


X«—[addrj 

Nuii-Seite direkt 


96 P» 

2 

4 

X 




X 


X—[aci<Jr<-Y) 

Nuii-Seile indiziert 


AE »»qq 

3 

4 

X 




X 


X—[addrlß] 

Erweitert indiziert 

addrlö.Y 

BE »pqa 

3 

4" 

X 




X 


X«—[addrl6+Y] 

Absolul mdizieit 

STX 










Speichere Index-Re9 X zum Speicher 

. Index nur über Reg Y 


86 pp 

2 

3 







(addr|*—X 

Nu. -Seile direkt 


96 pp 

2 

4 







[addr+Y|v~x 

Nutl-Seite indiziert 

addr16 

8E ppqq 

3 

4 







[addr16j<--X 

Erweilert direkt 

LiY 










Lade Index-Register Y vom Speicher 

Index nur über Register X. 


A4 pp 

2 

3 

X 




X 


YHaddr] 

Null-Seile direkt 


#4 PP 

2 

4 

X 




X 


Y—|addr+X| 

Nuii-Seile mdrziert 

addr16 

AC ppqq 

3 

4 

X 



X 


Y—|addr16l 

Erweitert direkt 

addrl 6.X 

BC ppqq 

3 

4' 

X 



X 


Y.—|addrl6+X| 

Absolul Indizien 


"Addiereeme Taktoenode.wenn eine Senen-Gienze uberschnlten wud. 

Im Objekt-Code ze»gl ’X" das Index-Re9ister an: X-0 tur Regisler Y, X=1 Jur Register X 


Tabelle 3-4. Eine Zusammenfassung des 6502-Befehissatzes (Fortsetzung) 


Typ 

Befehl 

Objekt-Code 

Byte 

Takt- 

Perio- 

Status 

Atisgeführte OPeration 











den 

N 

V 

D 

1 

Z 

c 


4 

STY 










Speichere Index-Regisler V zum Spercher. Index nur über Register X. 

5 2 

addr 

84 pp 

2 

3 







[addr)+-Y Null-Seite direkt 

w r. 

addr.X 

S4 CR 

2 

4 







[addr+X|«-Y Null-Seite indiziert 

in 8. 

addr16 

8C ppqq 

3 

4 







[addr161+-Y Erweitert direkl 

•s 

.c 
t o 
£ « 
o. a 

. W 

3 C 
< « 

Ui 













ADC 










Addiere Inhalt des Speicherplatzes mft Übertrag zu jenem des Akkumul. 


addr 

65 pp 

2 

3 

X 

X 



X 

X 

A*-A-i-[addr]+C Null-Seite direkl 


addr.X 

75 cp 

2 

4 

X 

X 



X 

X 

A^A+[addr+X|+C Null-Seite indiziert 


(addr.X) 

61 CP 

2 

6 

X 

X 



X 

X 

A+-A+[[addr+X]j+C Vor-indiziert indirekt 


(addrJ.Y 

71 PR 

2 

5* 

X 

X 





A—A-*-[[addr+1, a ddr]+Y]-»-C Nach-indiziert indirekt 

"c 

add16 

6D ppqq 

3 

4 

X 

X 





A«—A+(addrl6]+C Erweitert direkt 

C £ 

addrl6,Xod. Y 

01114x01 ppqq 

3 

4* 







A+-A-f(addri6+X]-*-C od. A+-A+[addri6+-Y|+C Absolut indiziert 

< 5 
| £ 











(Nuli-Fiag istm der Dezimal-ßetriebsait nicht gültig) 

y 9 

AND 










UNDierelnhalt des Akkumulators mit lenem des Soeicherplalzes. 

a ® 

(/) ‘o 

t | 

n (/) 

addr 

25 *c 

2 

3 

X 






A+-A A[addi] Nuli-Seite direkl 

addr.X 

35 *c 

2 

4 

X 






A*-AA [addr+Y| Null-Seite indiziert 

(addr.X) 

21 pp 

2 

6 

X 






A-*-A A[[addr+X|| Vor-indiziert indirekt 

2 c 

(addr).Y 

3 1 »c 

2 

5* 

X 






A*-A.A[[addr+1, addr)+Y Nach-indizirt indirekt 

iZ 

addrl 6 

2D ppqq 

3 

4 

X 






A«—A A [addrl 6 ] Erweite 11 indiziert 

S> s 

addr16,Xod. Y 

00111x01 ppqq 

3 

4* 

X 






A«-A A[addr16+X]od A«—A \[addr16+Y] Absolut indiziert 

in 

BIT 










UNDiere Inhalt des Akkumulators mit lenem des Speicherplatzes. Es werden 
nur die Status-Bits beeintlußt 


addr 

24 pp 

2 

3 

7 

6 





AA|addr] Null-Seite direkt 


addrl 6 

2C ppqq 

3 

4 

7 

6 





AA (addrl 6J Erweitert direkt 


"Addiereeme Taktperfode, wenn efneSeiien-Crenze überschritten wird. 

Inn Objekt-Code zeigt "X'" das Index-Register an: X-Otür Register Y, X-1 für Regisler X. 
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Tabelle 3-4. Eine Zusammenfassung des 6502-Befehlssatzes (Fortsetzung) 


Typ 

Befehl 

Objekt-Code 

Byte 

Takt- 

Status 



Perlo- 












den 

N 

V 

D 

1 

z 

c 




CMP 










Vergleiche den Inhalt des Akkumulators mit jenem des Speicherplatzes 












Nur die Status-Bits werden beeinflußt. 



addr 

C5 cp 

2 

3 

X 




X 

X 

A-[addr| 

Nullseile direkt 

C 

addr.x 

05 pp 

2 

4 

X 




X 

X 

A-[addr+X| 

Nullseite indiziert 

N 

(addr.X) 

Ci co 

2 

6 

X 




X 

X 

A ([addr-vXj] 

Venndiziert indirekt 

CO 

(addr),Y 

Dl co 

2 

5* 

X 




X 

X 

A [[addr+1, addr|+Y| 

Nachndi 2 iertlndirekl 

c 

addrlS 

CD ppqq 

3 

4 

X 




X 

X 

A [addrl 6] 

Eiweilerl direkt 

u. 

addrl 6,Xod Y 

11011x01 ppqq 

3 

4‘ 

X 




X 

X 

A-(addr16fX] oder A (addr16fY) 

Absolut mdl 2 erl 

c 

2 

EOR 










Exklusiv-ODERiere den Inhall des Akkumulators mit jenem des 

« 











Speicherplatzes 


a. 

addr 

4500 

2 

3 

X 




X 


A*-A-V-[addrj 

Nullseite direkt 


addr,X 

55 pp 

2 

4 

X 




X 


A*-A-V-[addr+X| 

Nullseite indiziert 

s 

(addr.X) 

41 00 

2 

6 

X 




X 


A*-A -V-[[addr+Xjj 

Vormdizierl indirekt 

I 

(addrj,Y 

5t pp 

2 

5* 

X 




X 


A«-AJ/J|addr+1 addr]+Yj 

Nachmdi 2 ierl indirekt 

addr 16 

4 0 ppqq 

3 

4 

X 




X 


A«-A4Haddrl6| 

Eiweilert direkt 

c 

c 

addri6.Xod Y 

01011 x 01 ppqq 

3 

4* 

X 




X 


A.-A-V-i ddrl6*X| od A. A-w-Iaddrl6hV| 

Absolut mdi 2 ierl 

o 

ORA 










ODERiere den Inhall des Akkumulators mil lenem des Speicherplatzes 

a 

addr 

05 pp 

2 

3 

X 




X 


A«~AV[addrJ 

Nullseile direkt 

c 

addr.x 

15 00 

2 

4 

X 




X 


A«-AV[addr+X| 

Nullseile indiziert 


(addrX) 

01 CD 

2 

6 

X 




X 


A^AV((addr*X]] 

Vorindi 2 iert indirekt 

J: 

(addr),Y 

1 1 00 

2 

5* 

X 




X 


A*_AV(addr+1. addr]+Y] 

Nachindiziert indirekt 

'S 

addri6 

OD ppqq 

3 

4 

X 




X 


A«~AV(addrl61 

Erweiterl direkt 

<r> 

•» 

2 

■D 

C 

3 

j£ 

a> 

V) 

addri6,X od, Y 

000 11 xOl ppqq 

3 

4* 

X 




X 


A* AV[addrl6>X| od. A* AV[addr1 6*-V] 

Absolut indiziert 


’ Addiere eine Taktperiode, wenn eine Seiten-Grenze überschritten wird 
Im Oblekt-Code zeigt X'das Index-Register an: lür Regisler Y. X-1 Kr Regisler X 


Tabelle 3-4 Eine Zusammenfassung des 6502-Befehlssatzes (Fortsetzung) 


Typ 

Befehl 

Objekt-Code 

Byte 

Takt- 

Perio¬ 

den 

Status 

Ausgeführte Operation 

N 

V 

D 

1 

z 

c 


SBC 










Subtrahiere Inhalt des Speicherplatzes, mit Borgen, vom Inhalt des 












Akkumulators 


addr 

E5pp 

2 

3 

X 

X 



X 

X 

A»~A-|addrl-C Nullseite direkl 

n> 

addr.X 

F5 00 

2 

4 

X 

X 



X 

X 

A«~A-|addr*XJ-C Nullseile Indizien 

s 

(addr.X) 

El 00 

2 

6 

X 

X 



X 

X 

A*-A-||addr*XlhC Vorindl 2 >ert indirekt 


(addr.)Y 

Fl 00 

2 

5* 

X 

X 



X 

X 

A*-A-[|addr*l. addrJ+Y)-C Nachmdi 2 iert indirekl 

r 

addr16 

EOooqq 

3 

4 

X 

X 



X 

X 

A*-A-[addr 16}-C Erweitert direkl 

£ 

addrl 6,X od. Y 

1111 1x01 Ppqq 

3 

4" 

X 

X 



X 

X 

A*-A-[addr16*X}-C od, A*-A-[addrl6+Y| C Absolullndizlerl 












(Beachte, daß der Übertrags-Wert das Komplement des Borgens isl.) 

'S 

iNC 










Inkrementiere inhall des Speicherplatzes Index nur über Register X. 

K 

addr 

E6PD 

2 

5 

X 




X 


[addr[*-[addr)+l Nullselle direkl 

o 

addr.x 

FSOO 

2 

6 

X 




X 


[addr+Xl«-[addr*YJ+1 Nullseile indiziert 

® 

addrl6 

EE ooqq 

3 

6 

X 




X 


[addr16]*-[addr16]*l Erweitert direkl 

o 

*5 

addrl6,X 

FE ppqq 

3 

7 

X 




X 


[addrl6+X|«-[addrt6+Xl*1 Absolut indi 2 ien 

& 

DEC 










□ekremenliere Inhalt des Speicherplatzes. Index nur über Register X 

© 

addr 

C6pp 

2 

5 

X 




X 


[addr)«-(addr)-l Nullseile direkt 

u 

addr.X 

D6pp 

2 

6 

X 




X 


[addr*XJ*-[addr*X|-l Nullseite indiziert 

a 

addri6 

CE ppqq 

3 

6 

X 




X 


(addrl6]*-(addrl61—1 Erweitert direkl 

c 

< 

addrl6.X 

DE DOqq 

3 

7 

X 




X 


[addrl6+X|-1 Absolut indi 2 ieri 

« 

.c 

CpX 










Vergleiche Inhall von Register X mil jenem des Speicherplatzes Nur 












die Statusflags werden beemllu6t. 

a 

addr 

E4 pp 

2 

3 

X 




X 

X 

X-[addr] Nullseite direkt 

« 

addr 16 

EC ppqq 

3 

4 

X 




X 

X 

X-[addM6] Erweitert direkt 


CPY 










Vergleiche der inhattvon Register Y mit lenem des Speicherplatzes 

3 











NurdieStalusllags werden beeinflu6l 

C3 

V) 

addr 

C4 DP 

2 

3 

X 




X 

X 

Y-(addr| Nullseite direkt 


addr16 

CCppqq 

3 

4 

X 




X 

X 

Y-[addriS] Erweitert direkl 


’Addrere eine Taktperiode, wenn eine Seilen-Grenze überschritten wird 
Im Objekt-Codezeigl X ‘das index Reg sler an: X^)tür Register Y. X-1 lür Register X. 
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Tabelle 3-4. Eine Zpsammenfassung des 6502-Befehlssatzes (Fortsetzung) 


Typ 

Befehl 

Objekt-Code 

Byte 

Takt- 

Perio¬ 

den 

Status 

Ausgeführte Operation 

N 

V 

0 

1 

z 

c 


ROL 










Rohere Inhalt des Speicherplatzes um ein Bit nach links durch den 












Übertrag. Index nur durch Register X 


addf 

26 DP 

2 

5 

X 




X 

X 


[addr] 

o 

c 

addr.X 

36 pp 

2 

6 

X 




X 

X 


[addr+X] 

M 

addrt6 

2E ppqq 

3 

6 

X 




X 

X 


[addr16] 

® 

«0 

■e 

o 

U- 

■c 

addrt6,X 

3E ppqq 

3 

7 

X 




X 

X 

l *GH 

[addrl6+X| 

7 -o |<«-l 















ROR 










Rotiere Inhalt des Speicherplatzes um ein Bit nach rechts. Index nur 

O 











durch Register X 



addr 

66 DP 

2 

5 

X 




X 

X 


[addr] 

-e 

u 

addr.X 

76 pp 

2 

6 

X 




X 

X 


laddr+X] 

a> 

addrl6 

6E pp 

3 

6 

X 




X 

X 


[addri6] 

</> 

c 

• 

£ 

o 

2 

a 

addrl6,X 

7 E ppqq 

3 

7 

X 




X 

X 

Lrru. 

[addrt6+X] 

|7__* L 0jj 

e 

< 

ASL 










Verschiebe Inhalt des Speicherplatzes arithmetisch nach links. Index nur 

-r 











durch Register X 



addr 

06 DP 

2 

5 

X 




X 

X 


laddr] 

Q 

addr.X 

16 DP 

2 

6 

X 




X 

X 


|addr+X] 


addrl 6 

OEppgq 

3 

6 

X 




X 

X 


[addrt6] 

X« 

~U 

addr16.X 

1 E ppqq 

3 

7 

X 




X 

X 


|3ddrl6-eX] 

n 

® 











EM 

7 - 0 ^»0 


'Addiere emeTaklpenode, wenn eine Seilen-Grenze überschrMlen wird. 

Im Objekl-Code zeigt W X" das Index-Register an: X-0 für Register Y, X-1 lür Register X. 


Tabelle 3-4. Eine Zusammenfassung des 6502-Befehlssatzes (Fortsetzung) 






Takt- 


Status 





Typ 

Befehl 

Objekt-Code 

Byte 

Perio- 





Ausgeführte Operation 












den 

N 

V 

D 

1 

Z 

c 




LSR 










Verschiebe Inhalt des Speicherplatzeslogisch nach rechts Index nur 

Q. ^ 

s4 

addr 

46 pp 

2 

5 

0 




X 

X 

durch Register X. 

[addr] 

< o 

addr.X 

66 PP 

2 

6 

0 




X 

X 


[addr+X] 

® w 

addr16 

4Eppq« 

3 

6 

0 




X 

X 


|addrt6] 

ü "2“ 
ä> is 

a a 

c/> o 

(A w 

addrl6,X 

5E PPQQ 

3 

7 

0 




X 

X 


[addrlÖ.Xj 











H 

» r L J " 1 

iS 

§ S 

-* V) 











7 •» T 1 














lDa data 

AS PC 

2 

2 

X 




X 


Lade Akkumulator mil unmittelbaren Daten | 












A.-data 



LfrXdata 

A2 DP 

2 

2 

* 




X 


Lade Index-Register X mit unmittelbaren Daten. 












X—data 



LlYdata 

AO DP 

2 

2 

X 




X 


Lade Index-Register Y mit unmittelbaren Daten, 












Y-i-data 


m 

£ 













■v 













I 













3 














'Addiere eine Taklperiede. wenn etne Seiten-Grenzeüberschritten wird. 

Im •btekt-Code zeigt “X 'das Index-Register anrX =4) für Register Y,X-1 lür Register X. 
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Tabelle 3-4. Eine Zusammenfassung des 6502-Befehlssatzes (Fortsetzung) 


Typ 

Befehl 

Objekt-Code 

Byte 

Takt- 

Perio¬ 

den 

Status 

Ausgefühlte Operation 

N 

V 

0 

1 

z 

c 




2 

2 

X 

X 



X 

X 

Addiere unmittelbar mit Übertrag zum Akkumulator, Das Null-Flag isl 












in der lezimalbelnebsart nietet gültig. 












A«-Andata+C 


ANOdata 

29 CP 

2 

2 

X 




X 


UNOiere unmittelbar mil Akkumulator. 












A«—A data 



C9 PP 

2 

2 

X 




X 

X 

Vergleiche unmittelbar mit Akkumulator, Nur die Statusflags werden 












beeinflußt 

o 











A data 

<0 

EORdata 

49 CP 

2 

2 

X 




X 


Exklusiv-ODERiere unmittelbar mit Akkumulater, 

Q. 











A*—A-V- data 

o 

ORA data 

09 PP 

2 

2 

X 




X 


ODERiere unmittelbar mit Akkumulator. 












A<—A Vdata 

£ 

<u 

SBCdata 

E9pp 

2 

2 

X 

X 



X 

X 

Subtrahiere unmittelbar, mit Bergen, vom Akkumulator 












A«--A-dala-C 

£ 











(Beachten Sie, daß der Weit des Übertrags das Komplement des "Borgens“ ist.) 



ECl»» 

2 

2 

X 




X 

X 

Vergleiche unmittelbar mit Index-Register X. Nur die Statusflags werden 












beeinllußl- 












X data 


CPY data 

CO pp 

2 

2 

X 




X 

X 

Vergleiche unmittelbar mil tndex-Register Y. Nur die Slatusllags werden 












beeinflußt. 












Y-data 



4C PP*q 

3 

3 







Springe zum nächsten Speicherplatz unter Verwendung erweiterter oder 












indirekter Adressierung 

05 

(labei) 

6C CCdd 

3 

5 







PC* -labei oder PO-flabel) 

3 

O. 

m 













'Addiere eine Taktperiode, wenneine Seiten-Grenze überschritten wird. 

Im Objekt-Code zeigt "X" das Index-Register an: X.O für Register Y. X-1 für Register X. 


Tabelle 3-4. Eine Zusammenfassung des 6502-Befehlssatzes (Fortsetzung) 


TyP 

Befehl 

Obje t Code 

Byte 

Takt 

Perio¬ 

den 

Status 

Ausgeführte Operation 

N 

V 

D 

1 

Z 

c 












Beachten Sie folgendes für alle bedingten Verzweigungs-Befehle: 












Wenn die Bedingung befriedigt wird, s« wird die Versetzung zum 












Befehlszähler addiert, nachdem der Befehlszähler inkrementiert worden 












ist, um zu dem Befehl zu zeigen, der dem Verzweigungsbefehl lolgf. 


BCC disp 

90 PP 

2 

2" 







Verzweige relativ, wenn Überlrags-Fiag gelöscht ist 












Wenn OO. dann PC« -PC+disp 


BCS disp 

BO pp 

2 

2" 







Verzweige relativ, wenn Überlrags-Fiag gesetzt ist. 












Wenn Ot.dann PC« -PC+disp 


BEOdisp 

FOpp 

2 

2** 







Verzweige relativ, wenn Ergebnis gleich null ist. 












Wenn Z«1 , dann PC«-PC+disp 


BMI disp 

30 pp 

2 

2 *“ 







Verzweige relativ, wenn Ergebnis negaliv isl. 

0» 











Wenn N-1, dann PC+-PC+disp 

3 

BNE disp 

DO PP 

2 

2** 







Verzweige relativ, wenn Ergebnis nicht null ist. 

© 











Wenn 2-0, dann PC« -PC+rfisp 

§ 

BPLd.sp 

lOpp 

2 

2'* 







Verzweige relativ, wenn Ergebnis positiv ist 

© 











Wenn N-#,dann PC«.-PC+disp 


BVC disp 

50pp 

2 








Verzweige relativ, wenn Überlauf-Flag gelöscht ist. 

ö, 










■ 

Wenn V-0. dann PC«.-PC+disp 

'■ö 

BVSdisp 

ropp 

2 








Verzweige relativ, wenn Überlauf-Flag gesetzt ist. 

ca 











Wenn V=1, dann PC« -PCndisp 


‘Addiere eine Taktperiode, wenn die Verzweigung zu einem Speicherplatz aut derselben Seite autlntl. Addiere zwei Taklperioden, wenn die Verzweigung 
zu einer anderen Seite auitritt. 
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Tabelle 3-4. Eine Zusammenfassung des 6502-Befehlssalzes (Fortsetzung) 


Typ 

Befehl 

Objekt-Code 

Byte 

Takt* 

Perio¬ 

den 

Status 

Ausgeführte Operation 

N 

V 

0 

1 

z 

c 

■C 

JSH labei 

20 ppqtj 

3 

6 







Springe zu Unterprogramm, beginnend bei der Adresse, die durch die 

JC 











Bytes 2 und 3 des Belehis angegeben werden. Beachten Sie. daß der 

o 











gespeichene Befehlszähler zum letzten Byte des JSR-Belehls zeigt 

er 











fSPj<-PC(HI) 

TJ 











fSP- 1 ]<-PC{LO) 

3 











SP<-SP-2 

3 











P «-labei 

3 

RTS 

60 

l 

6 







Kehre von Unterprogramm zurück und inkrementiere hierbei den 












Befehlszähler, um zu dem Befehl nach dem JSR zu zetgen. der die Routi- 

E 











ne aufriet. 












PC(LQ).— (SP+13 

o 











PC(HlMSP+2j 

8 











SP*—SP«-2 












PC—PC+1 














TAX 

AA 

1 

2 

X 




X 


Bringe Akkumulator-Inhalt zum Index-Register X. 












X«—A 


TXA 

8 A 

1 

2 

X 




X 


Bringe Inhalt des Index-Registers X zum Akkumulator 

o 











A—X 


TAY 

A8 

1 

2 

X 




X 


Bringe Akkumulator-Inhall zum Index-Register Y 

a 











Y«-A 


TYA 

»8 

1 

2 

X 




X 


Bringe Inhalt des Index-Regislers Y zum Akkumulator. 

© 











A^Y 

ö> 

TSX 

BA 

1 

2 

X 




X 


Bringe Inhaltdes Siapelzeigers zum Index-Register X. 

DL 











X«-$P 

3 

TXS 

9A 

1 

2 







Bringe Inhaltdes Index-Registers X zum Stapelzeiger. 












SP^-X 

« 












o> 

© 












cc 













Tabelle 3-4. Eine Zusammenfassung des 6502 Befehlssatzes (Fortsetzung) 


Typ 

Befehl 

Objekt-Code 

Byte 

Takt- 

Perlo¬ 

den 

Status 

Au geführte Operation 

N 

V 

D 

i 

z 

c 


DEX 

CA 

1 

2 

X 




X 


Oekrementierelnhall von Index-Regisier X. 












X«-X-1 


iEY 

88 

1 

2 

X 




X 


Oekrementiere Inhall von Index-Register Y, 












Y*—Y-1 


INX 

E8 

1 

2 

X 




X 


Inkrementiere Inhalt von Index-Register X. 












X«--X«-1 


INY 

C8 

1 

2 

X 




X 


Inkrementiere Inhalt von Index-Register Y. 












Y—Y+1 


R*LA 

2A 

1 

2 

X 




X 

X 

Rotiere Inhaltdes Akkumulators nach links durch Übertrag. 

L| C }-«-] 7 - ) j^-1 

C 

o 











A 

Io 

RORA 

6A 

1 

2 

X 




X 

X 

Rotiere Inhalt des Akkumulalors nach rechts durch Übertrag. 

a 











1 ~x 1 












L»4 C 7 -► 0 LJ 









© 











A 


ASL A 

0A 

1 

2 

X 




X 

X 

Verschiebe Inhalt des Akkumulators arithmetisch nach links. 












EH ' »H* 


LSR A 

4 A 

1 

2 

0 




X 

X 

A 

Verschiebe Inhall des Akkumulators arithmetisch nach rechts. 












H' - H c 1 












A 
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Tabelle 3-4. Eire Zusammenfassung des 6502-Befehlssatzes (Fortsetzung) 


Typ 

Befehl 

Objekt-Code 

Byte 

Takt- 

Status 


Perlo- 







Ausgeführte Operation 





den 

N 

V 

0 

1 

z 

c 



PNA 

48 

1 

3 







Bringe Akkumulator-Inhall zum Slapel. 


PLA 










|SP|<—A 

SP4-SP-1 


68 

1 

4 

X 




X 


Lade Akkumulator von der Spitze des Slapels (“Pull''). 

_ 











Aw|SP+1) 

Q. 











SP—SP+1 

35 

PHP 

03 

1 

3 







Bringe Stalusragister-Inhall zum Slapel. 

PLP 










(SP)v-P 

SP«--SP-1 



28 

1 

4 

X 

X 

X 

X 

X 

X 

Lade Sialusregister von der Spitze des Stapels ( ‘full' ) 












PHSP+i) 

SP—SP+1 


CLI 

58 

1 

2 




0 



Gib Unterbrechungen durch Loschen des Unterbrechungs-Freigabe-Bils des J 
Slalusregistersfrei. 


SEI 










1»—0 


78 

1 

2 




1 



Sperre Unterbrechungen. 


RTI 

40 

1 

6 

X 

X 

X 

X 

X 

X 

Kehre von Unlerbrechung zurück, speichere Stalus zuruck. 












P—(SP+1| 

o> 











PC(LO)HSP+2| 

D 











PC(HI)«—(SP*3) 

O 











SP«—SP+3 

£ 

BRK 










PC—PC+1 


00 

1 

7 




1 



Programmierte Unterbrechung. BBK kann nicht gesperrt werden. Per 

c 











Programmzähler wird zweimal mkrementierl, bevor er im Slapel 












aufbewahrl wird. 












|SPK-PC(HI) 

|SP-1)«-PC(Lt) 

|SP-2|<—P 

SP—SP-3 

PC(HI)—|FFFF| 

PC(LO)«--[FFFE| 
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Tabelle 3-4. Eine Zusammenfassung des 6502-Befehlssatzes (Fortsetzung) 


Typ 

Befehl 

Objekt Code 

Byte 

Takt- 

Perio¬ 

den 

Status 

Ausgeführte Operation 

N 

V 

O 

1 

z 

c 


CLC 

18 

1 

2 






0 

Lösche Ubertrags-Flag 












C<-0 


SEC 

38 

1 

2 






1 

Setze Ubeitrags-Flag 












tvi 

<& 

CLO 

D8 

1 

2 



0 




Lösche Dezimal-Betriebsart 

s 











• -0 

</> 

SED 

F8 

1 

2 



1 




Setze Dezimai-ßetriebsarl 












•«-1 


ClV 

BB 

1 

£ 


0 





Lasche Überlauf-Flag 












v—o 


NOP 

EA 


2 







Keine Operation 





Tabelle 3-5. Tabelle der Objektcodes der Befehle des 6502 in numerischer 


Reihenfolge 


Obiektcode 

Befehl 


OCiektcoda 

Befehl 

00 

BRK 



68 

jMSM' 


01 pp 

ORA 

laddrXl 


69 pp 


dal» 

05 pp 

ORA 

addr 


6A 


A 

06 pp 

ASL 

addr 


6C ppqq 


(tabaii 

08 

PHP 



60 ppqq 


addr 16 

09 pp 

ORA 

data 


6E ppqq 


addrie 

OA 

ASL 

A 


70 pp 


dup 

00 ppgq 

ORA 

addrie 


71 pp 


(addrl.Y 

oe pp<n 

ASL 

addr 16 


75 pp 

AOC 

addr X 

10 pp 

BPI 

dap 


76 PP 

ROR 

addr.X 

1 1 pp 

ORA 

IkMiI Y 


78 

SEI 


15 pp 

ORA 

addr X 


79 ppqq 

AOC 

addr 18 .Y 

16 pp 

ASL 

addr.X 


70 ppqq 

AOC 

addrie.X 

16 

CLC 



7E ppqq 

ROR 

addrie.X 

19 ppqq 

ORA 

addrlß.Y 


81 pp 

STA 

(addr.X! 

1 0 ppqq 

ORA 

addrie X 


84 pp 

STY 

addr 

IE ppqq 

ASL 

addrie.X 


85 pp 

STA 

addr 

20 ppqq 

JSR 

label 


86 pp 

STX 

addr 

21 pp 

ANO 

(addr.xl 


88 

OEY 


24 pp 

BIT 

addr 


8A 

TXA 


25 pp 

ANO 

addr 


dC ppqq 

STY 

addrie 

26 PP 

ROL 

addr 


60 ppqq 

STA 

addrie 

28 

PLP 



8E ppqq 

STX 

addrie 

29 pp 

ANO 

daia 


90 pp 

BCC 

dap 

2A 

ROL 

A 


91 pp 

STA 

(addrl.Y 

2C ppqq 

BIT 

addr 18 


94 pp 

STY 

addr.X 

20 ppqq 

AND 

addr 16 


95 pp 

STA 

addr.X 

26 ppqq 

ROL 

addr 1 e 


96 pp 

STX 

addr.Y 

30 pp 

BMI 

d»$p 


98 

tya 


3l pp 

AND 

(addrl.Y 


99 Ppqq 

STA 

addrie Y 

35 pp 

ANO 

addt X 


9a 

TXS 


36 PP 

ROL 

addr M 


90 ppqq 

STA 

addrie.X 

36 

SEC 



AO pp 

LDY 

data 

39 ppqq 

AND 

»ddrie.Y 


Al pp 

LDA 

(addr.X! 

30 ppqq 

AND 

addrie.X 


o 

Q 

04 

< 

LDX 

data 

3E ppqq 

ROL 

addrie.X 


A4 pp 

LDY 

addr 

40 

RTI 



A5 pp 

LDA 

addr 

4l pp 

EOR 

iaddr XI 


A6 pp 

LDX 

addr 

45 pp 

EOR 

addr 


AB 

TAY 


46 pp 

LSR 

addr 


A9 pp 

LDA 

data 

48 

PHA 



AA 

TAX 


*9 PC 

EOR 

dal» 


AC ppqq 

LDY 

addrie 

4 A 

LSR 

A 


AD ppqq 

LDA 

addrie 

4C ppqq 

JMP 

label 


AE ppqq 

LOX 

addrie 

40 ppqq 

EOR 

addrie 


60 pp 

BCS 

disp 

4E ppqq 

LSR 

addrie 


Bl pp 

LDA 

(addrl.Y 

50 pp 

BVC 

dup 


04 pp 

LDY 

addr.X 

St pp 

EOR 

(addr).Y 


85 pp 

LDA 

addr.X 

55 pp 

EOR 

addr X 


66 pp 

LDX 

addr.Y 

56 PP 

LSR 

addr.X 


66 

CLV 


56 

CU 



69 ppqq 

LDA 

addrie Y 

59 ppqq 

EO« 

addrie.Y 


BA 

TSX 


50 ppqq 

EOR 

•ddds.x 


BC ppqq 

LDY 

addrie.X 

5E ppqq 

LSR 

addr 16 X 


00 ppqq 

LOA 

addrie.X 

60 

RTS 



8€ DPqq 

LDX 

addrie.Y 

61 PP 

AOC 

(addr.X! 


CO pp 

CPY 

dal» 

65 po 

AOC 

addr 


CI pp 

CMP 

laddi.XI 

66 pp 

ROR 

addr 


C4 pp 

CPY 

addr 


Tabelle 3-5. Tabelle der Objektcodes der Befehle des 6502 in numerischer 
Reihenfolge (Fortsetzung) 


Obtektcode 

Befehl 


Obfektcode 

Befehl 

C5 pp 

CMP 

addr 


BEB 

CPX 


C6 pp 

DEC 

addr 


w'rw-: 

SBC 


CB 

INY 



mxm - 

INC 


C9 pp 

CMP 

data 


'•En: ft 

INX 


CA 

OEX 



■ÜSifj 

SBC 


CC ppQq 

CPY 

addrie 


EA 

NOP 


CD ppqq 

CMP 

addrie 


EC ppqq 

CPx 


CE ppqq 

OEC 

addrie 


EO ppqq 

SBC 


DO pp 

BNE 

d'«p 


EE ppqq 

WC 


01 pp 

CMP 

(addrl.Y 


EO PO 

8EQ 

disp 

05 pp 

CMP 

addr.X 


Fl PP 

SBC 

laddrl.Y 

06 PP 

DEC 

addr.X 


F5 pp 

SBC 

addr.X 

08 

CLD 



F6 pp 

INC 

addr.X 

09 ppqq 

CMP 

addrie, Y 


FB 

SEO 


00 ppqq 

CMP 

addrie.X 


F9 ppqq 

SBC 

addrie Y 

OE ppqq 

DEC 

addrie.X 


EO ppqq 

SBC 

addr 16.X 

CO pp 

CPX 

daia 


EE ppqq 

INC 

addrie.X 

El pp 

SBC 

(addr XI 
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Die folgenden Symbole werden in den Objektcodes in Tabelle 3-6 verwendet. 

Auswahl der Adressier-Art: 

aaa 

000 vor-indiziert indirekt- (addr.X) 

001 direkt-addr 

010 unmittelbar-data 

011 erweitert direkt- addrl 6 

100 nach-indiziert indirekt — (addr),Y 

101 Basis-Seite indiziert-addr.X 

110 absolut indiziert - addr16,Y 

111 absolut indiziert-addr16,X 

bb 

00 direkt - addr 
01 erweitert direkt-addrl6 

10 Basis-Seite indiziert-addr.X 

11 absolut indiziert:— addr16,X 

bbb 

001 direkt-addr 

010 Akkumulator-A 

011 erweitert direkt- addr16 

101 Basis-Seite indiziert- addr.X, addr,Y in STX 

111 absolut indiziert — addr16.X, addr16,Y in STX 

cc 

00 unmittelbar - data 
01 direkt-addr 

II erweitert direkt-addr16 

ddd 

000 unmittelbar-data 

001 direkt - addr 

011 erweitert direkt-addr16 

101 Basis-Seite indiziert- addr.Y in LDX; addr.X in LDY 

III absolut indiziert- addr16,Y in LDX; addr16,X in LDY 

pp Das zweite Byte eines Zwei- oder Drei-Byte-Befehls. 

qq Das dritte Byte eines Drei-Byte-Befehls. 

x Ein Bit, das die Adressen-Art wählt: 

0 direkt-addr 
1 erweitert direkt - addrlß 

Y Ein Bit, das die JMP-Adressier-Art wählt: 

0 erweitert direkt-Markierung 
1 indirekt-(Markierung) 


Tabelle 3-6 Zusammenfassung der Objektcodes des 6502 mit Mnemoniks des 
_ 6800 _ 


Mnemonik 

Operand 

Objektkode 

Byte» 

Takt 

Perioden 

MC6800- 

Befehl 

ADC 


01 1 aaa 01 



ADCA 


data 

PP 

2 

2 

daiaB 


addr 

PP 

2 

3 

addrB 


addr.X 

PP 

2 

4 

index 


(addr.X) 

PP 

2 

6 



(addr).Y 

PP 

2 

5' 



addr16 

PPnq 

3 

4 

addr16 


addr16,X 

ppqq 

3 

4* 



addr16,Y 

ppqq 

3 

4‘ 


AND 


OOlaaaOl 



ANDA 


data 

PP 

2 

2 

dataB 


addr 

PP 

2 

3 

addr8 


addr.X 

PP 

2 

4 

Index 


(addr.X) 

PP 

2 

6 



(addrl Y 

PP 

2 

5* 



addrlfi 

ppqq 

3 

4 

addrIB 


addr16X 

ppqq 

3 

4' 



addr16,Y 

Ppqq 

3 

4* 


ASL 

A 

OOObbblO 

1 

2 

ASLA 


addr 

PP 

1 

5 



addr.X 

PP 

2 

6 

ASL mlex 


addr16 

ppqq 

3 

6 

ASL addr 16 


addr16,X 

ppqq 

3 

7 


BCC 

disp 

90 pp 

2 

2** 

GCC disp 

BCS 

disp 

BO pp 

2 

2** 

BCS disp 

8£Q 

disp 

FOPP 

2 

2*’ 

BEO disp 

WT 


0010x100 



BITA 


addr 

pp 

2 

3 

addrB 


addr16 

ppqq 

3 

4 

addrlß 

BW« 

disp 

30 pp 

2 

2~ 

BMI disp 

BNE 

disp 

0O PC 

2 

2*' 

BNE disp 

BPI 

disp 

|0 pp 

2 

2** 

BPLdisp 

8RK 


00 

1 

7 

ISwn 

BVC 

disp 

50 pp 

2 

2** 

BVC disp 

BVS 

disp 

70 pp 

2 

2T' 

0V$ disp 

CLC 


10 

1 

2 

CLC 

CLD 


D8 

1 

2 


CL1 


58 

1 

2 

CLI 

CLV 


00 

1 

2 

CLV 

1 Addiere eine Taktperiode, wenneine Seilen-Grenze überschritten wird 


"Addiere eine Taklperiode, wenn Verzweigung zum Speicherplatz in derselben Seite aultritt; 

j addiere zwei Taktperioden, wenn Verzweigung ZJ anderer Seile aultritl 

_ 
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Tabelle 3-6. Zusammenfassung der Objektcodes des 6502 mit Mnemoniks des 
_6600 (Fortsetzung)_ 


Mnemonik 

Operand 

CMP 

data 

addr 

addr.X 

laddr.XI 

(«ddrl.Y 

addr16 

addr16.X 

addr16, Y 

CPX 

dMB 

addr 

addr 16 

CPV 

data 

addr 

addr16 

DEC 

addr 

addr X 

addr16 

addr!6,X 

DEX 


DEY 


EOR 

dal« 

addr 

addr.X 

(addr.X! 
(eddr).Y 
addr 1 6 

addr16 X 

addrl6,Y 

INC 

addr 

addr.X 

eddr16 

addr16,X 

INX 


INY 


JMP 

iabe( 

(labe!) 

JSH 

labal 


Takt- 

Perioden 


MC6SOO- 

Befehl 



Addiere eine Taktperiode, wenn eme Seiten-Grenze überschritten wird 
“Addiere eine Taktperiode, wenn Verzweigung zum Speicherplatz in derselben Seile autfilt, 
addiere zwe Taklperioden, wenn Verzweigung zu anderer Sette aufmn 
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Tabelle 3-6 Zusammenfassung der Obiektcodes des 6502 mit Mnemoniks des 


6800 (Fortsetzung) 


Mnemonik 

Operand 

Objektcode 

Bytes 

Takt* 

Perioden 

MCS68<X> 

Befehl 

IDA 


lOTaaaOI 



IDAA 


data 

PP 

2 

2 

dataS 


addr 

pp 

2 

3 

ad<*8 


addr.X 

PP 

2 

4 

index 


(ad*.X> 

PP 

2 

6 



(addr).Y 

PP 

2 

5 * 



addr16 

Ppqq 

3 

4 

addM6 


addrl6,X 

PPQq 

3 

4 * 



addr!6,Y 

ppqq 

3 

4* 


LOX 


lOldddlO 



LOX 


data 

PP 

2 

2 

Idataö! 


addr 

PP 

2 

3 

addr 8 


addrY 

PP 

2 

4 

(mdexl 


addrlß 

Ppqq 

3 

4 

addrl6 


addr16. Y 

ppqq 

3 

4* 


IDY 


tOldddOO 





data 

PP 

2 

2 



addr 

PP 

2 

3 



addrX 

PP 

2 




eddr16 

ppqq 

3 




addr16.X 

ppqq 

3 



LSR 

A 

OlObbblO 

1 

2 

LSRA 


addr 

PP 

2 

6 



addr.X 

PP 

2 

6 

LSR index 


addr16 

ppqq 

3 

6 

LSR addr16 


addr16 X 

ppqq 

3 

7 


NOP 


£A 

1 

2 

NOP 

ORA 


OOOaaaOI 



ORAA 


data 

PP 

2 

2 

daia8 


addr 

PP 

2 

3 

addr8 


addr.X 

PP 

2 

4 

index 


laddr.XI 

PP 

2 

6 



laddrl Y 

pp 

2 

5* 



addrt6 

ppqq 

3 

4 

addr 16 


addrt 6.X 

ppqq 

3 

4* 



addr16 Y 

ppqq 

3 

4* 


PMA 


48 


3 

PSHA 

PHP 


08 


3 


PLA 


68 


4 

PULA 

PLP 


28 


4 


ROL 

A 

OOlbbblO 


2 

ROTA 


addr 

PP 


5 



addr.X 

PP 


6 

ROL mdex 


addr16 

ppqq 


6 

ROLaddr1€ ; 


addr!6.X 

ppqq 


7 


Addjere eine Taktperiode, wenn eine Senen-Grenze überschritten wird 


“Addiere eine Takipenode. wenn Verzweigung zum Speicherplatz in derselben Seite auttntt, 

addiere zwei Taktperioden, wenn Verzweigung zu anderer Seite aultritt 
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ADC- ADD-MEMORY, WITH CARRY, TO ACCUMULATOR 
(ADDIERE SPEICHER, MIT ÜBERTRAG, ZUM 
AKKUMULATOR) 

Dieser Befehl verwendet acht Arten der Adressierung des Datenspeichers und 
gestattet die Addition des Inhalts des Datenspeichers und des Übertrags-Status 
zum Akkumulator Die acht Aren der Speicher-Adressierung sind: 

1) Unmittelbar-ADC data 

2) Absolut (direkt)-ADC addr16 

3) Null-Seite (direkt)-ADC addr 

4) Vor indiziert mit Indexregister X - ADC (addr.X) 

5) Nach-indiziert mit Indexregister Y - ADC (addr).Y 

6) Null-Seite indiziert mit Indexregister X - ADC addr,X 

7) Absolut indiziert mit Indexregister X - ADC addr16,X 

8) Absolut indiziert mit Indexregister Y - ADC addr16,Y 

Das erste Byte des Objektcodes bestimmt wie folgt, welche Adressier-Art aus¬ 
gewählt wird: 


7 6 5 4 3 2 10 

loMlIaUlaloTTI 


Bil-Nummer 

Objekt-Code 


Bit-Wert 
für aaa 

Hexadezimaler 

Obtekt-Code 

Adressier-Art 

Anzahl 
der Bytes 

000 

61 

Indirekt, vor-indiziert mit X 

2 

001 

65 

Null-Seite (direkt) 

2 

010 

69 

Unmittelbar 

2 

011 

6D 

Absolut (direkt) 

3 

100 

71 

Indirekt, nach-indiziert mit Y 

2 

101 

75 

Null-Seite indiziert mit X 

2 

110 

79 

Absolut indiziert mit Y 

3 

111 

7D 

Absolut indiziert mit X 

3 


Wir können den ADC-Befehl mit unmittelbarer Adressierung wie anschließend 
gezeigt illustneren. Für andere Adressier-Arten schlagen Sie entweder die Be¬ 
sprechung der Adressier-Arten oder die Beschreibung anderer arithmetischer 
oder logischer Befehle nach, da die übrigen Darstellungen unterschiedliche 
Adressier-Arlen zeigen. 
















Addiere den Inhalt des nächsten Programmspeicher-Bytes (Adressier-Art. ge¬ 
wählt durch die Bits 2 3 und 4 des Bytes im Befehlsregister) mit dem Übertrags- 
Status zum Akkumulator Es sei angenommen x* = 3A 16 , yy = 7C 1S . C = 1 Nach¬ 
dem der Befehl 

ADC #$7C 

ausgeführt wurde, wird der Akkumulator B7 16 enthalten 

00111010 
01111100 

_ 1 _ 

10 110 1 11 

I Nicht-Nuli-Eroebnis setzt Z 
auf 0 


0 -V-1 =1, Setze V auf 1 



ADC ist der einzige Additionsbefehl des 6502. Um ihn in Emzetbyte-Operationen 
oder zur Addition der niederwertigen Bytes zweier Multi-Bytezahlen zu verwen¬ 
den, muß ein vorhergehender Befehl ausdrücklich den Übertrag auf Null setzen, 
so daß er die Operation nicht beeinflußt Beachten Sie, daß der Mikroprozessor 
6502 keinen Additionsbefehl besitzt, der den Übertrag nicht beinhaltet. ADC 
wird entweder binäre oder dezimate (BCD-) Addition ausführen, abhängig da 
von, ob das Ftag für den Dezimal-Betrieb 0 oder 1 ist. 
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AND - AND MEMORY WITH ACCUMULATOR 

(UNDiere SPEICHER MIT AKKUMULATOR) 

Dieser Befehl UNDiert logisch den Inhalt eines Speicherplatzes mit dem Inhalt 
des Akkumulators Dieser Befehl bietet die gleichen Speicher-Adressiermög- 
lichkeiten wie der ADC Befehl. Das erste Byte des Objektcodes wählt die Adres- 
sier-Art wie folgt 



Bit-Wert 
für aaa 

Hexadezimaler 

Obtekt-Code 

Adressier Art 

Anzahl 
der Bytes 

000 

21 

Indirekt, vor-indiziert mit X 

2 

001 

25 

Null Seite (direkt) 

2 

010 

29 

Unmittelbar 

2 

011 

2D 

Absolut (direkt) 

3 

100 

31 

Indirekt, nach-mdiziert mit Y 

2 

101 

35 

Null Seite indiziert mit X 

2 

110 

39 

Absolut indiziert mit Y 

3 

111 

3D 

Absolut indiziert mit X 

3 


Wir wollen den AND-Befehl mit einer (direkten) Adressierung der Seite Null illu- 
stneren Sehen Sie sich die Besprechung der Adressier-Methoden und anderer 
anthmetischer und logischer Befehle für Beispiele der anderen Adressier-Arten 
an. 


Daten- 



1 

2 


3-41 






UNDiere logisch den Inhalt des gewählten Speicherbytes mit dem Akkumulator 
und speichere das Ergebnis in den Akkumulator. Es sei angenommen xx - FC, S 
und yy= 13,6 Nach dem Befehl 

AND $40 

(angenommen, daß yy in Speicherplatz 0040 liegt) wird der Akkumulator 10i 6 
enthalten. 


FC 

13 


0 in Bit 7 setzt N auf 0 


= 11111100 
= 00010011 


0001 0000 

_l L 


Nicht Null-Ergebnis setzt Z auf 0 


AND ist ein häufig verwendeter logischer Befehl. 
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ASL -SHIFT ACCUMULATOR OR MEMORY BYTE LEFT 
(SCHIEBE AKKUMULATOR ODER SPEICHERBYTE 
NACH LINKS) 

Dieser Befehl führt eine arithmetische Links Verschiebung um ein Bit des Inhalts 
des Akkumulators oder des Inhalts des gewählten Speicherbytes aus. 
Betrachten Sie zuerst die Verschiebung des Akkumulators: 

Daten- 



Der Akkumulator enthalte angenommen 7A, a Bei der Ausführung des Befehls 

ASL A 

wird der Übertrags Status auf 0 gesetzt das Negativ-Bit auf l, der Null-Status 
auf 0 und es wird F4 16 in den Akkumulator gespeichert. 


Übertrag 


Setzt N auf 1 


Akkumulator 

- 01111010 - 

11110100 


Nicht-Null-Ergebms setzt Z auf 0 


Der ASL-Befehl verwendet vier Optionen für die Adressierung des Datenspei¬ 
chers 

1) Null-Seite (direkt)-ASL addr 

2) Absolut (direkt) - ASL addrlß 

3) Nuil-Seite indiziert mit Indexregister X ASL addr.X 

4) Absolut indiziert mit Indexregister X-ASL addrlß.X 

Das erste Byte des Objektcodes bestimmt, welche Adressier-Art wie folgt ge¬ 
wählt wurde: 


7 6 6 4 3 2 i o ■ 
[010(01 blb, I 1 I 1 I 0 I 


-Bit-Nummer 

-Objekt-Code 
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Bit Wert 
für bb 

Hexadezimaler 

Objekt-Code 

Adressier-Art 

Anzahl 
der Bytes 

00 

06 

Null-Seite (direkt) 

2 

01 

OE 

Absolut (direkt) 

3 

10 

16 

Null-Seite indiziert mit X 

2 

1 

IE 

Absolut indiziert mit X 

3 


Wir wollen den ASL-Befehl mit absoluter (direkter) Adressierung zeigen. Die an¬ 
deren Adressier-Arten sind bei anderen Befehls-Beschreibungen gezeigt. 

Oaterv 



Es sei angenommen ppqq - 3F86,$ und der Inhalt von ppqq sei CB,6- Nach Aus¬ 
führung eines Befehls 


ASL S3F86 

wird der Inhalt des Speicherplatzes 3F86, 6 auf 96, 6 geändert und der Übertrag 
auf 1 gesetzt: 


Übertrag 

x 

1 


Setzt N auf 1 


»86,6) 

-- 1 10 0 10 1 1 — 0 

100 1 0110 



Nicht-Null-Ergebnis setzt Z auf 0 


Der ASL-Befehl wird häufig in Manipulations-Routinen und als Standard-Logik¬ 
befehl verwendet Beachten Sie, daß ein einzelner ASL-Befehl seinen Operan¬ 
den mit 2 multipliziert 


BCC- BRANCH IF CARRY CLEAR (C = 0) 

(VERZWEIGE, WENN ÜBERTRAG GELÖSCHT) 

Dieser Befehl ist eine Verzweigung mit relativer Adressierung, bei dem die Ver¬ 
zweigung nur ausgefuhrt wird, wenn der Übertrags Status gleich 0 ist Andern¬ 
falls wird der nächste Befehl ausgeführt 

BCC 

90 

In der folgenden Befehls-Sequenz- 



BEFEHL 


wird der Befehl ADC $40 unmittelbar nach dem BCC-Befehl ausgeführt, wenn 
der LJbertrags-Status gleich 0 ist Der Befehl AND #$7F wird ausgeführt, wenn 
der Übertrags-Status gleich 1 ist. Die relative Adressierung arbeitet wie in der 
nächsten Abbildung gezeigt und wie in der Besprechung der früher dargelegten 
Adressier-Methoden. Keine Status und keine Register - mit Ausnahme des Be 
fehlszählers - werden beeinflußt. 


N V B D I Z C 

-C T.TT'1 n I 


Daten¬ 

speicher 



mmmm 
mrmiiTi ♦ 1 
rrvTTTWn ♦ 2 


mmrnm * n 


Wenn der Übertrag Null ist, so addiert dieser Befehl den Inhalt des zweiten Ob¬ 
jektcode-Bytes (genommen als 8 Bit Versetzung mit Vorzeichen) zum Inhalt des 
Befehlszählers plus 2 Dies wird die Speicher-Adresse für den nächsten auszu¬ 
führenden Befehl. Der vorhergehende Inhalt des Befehlszählers geht verloren 
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BCS - BRANCH IF CARRY SET (C = 1) 

(VERZWEIGE, WENN ÜBERTRAG GESETZT) 

Dieser Befehl arbeitet wie der BCC-Befehl mit der Ausnahme, daß die Verzwei¬ 
gung nur ausgeführt wird, wenn der Übertrags-Status gleich 1 ist Andernfalls 
wird der nächste Befehl ausgeführt. 

BCS 

BO 

In der folgenden Befehls-Sequenz: 



wird der Befehl ADC $40 direkt nach dem BCS-Befehl ausgeführt, wenn der 
Übertrags-Status gleich 1 ist. Der Befehl AND #$7F wird ausgefühil, wenn der 
Übertrags-Status gleich 0 ist. 


BEQ - BRANCH IF EQUAL TO ZERO (Z = 1) 

(VERZWEIGE, WENN GLEICH NULL) 

Dieser Befehl ähnelt weitgehend dem BCC-Befehl mit der Ausnahme, daß die 
Verzweigung ausgeführt wird, wenn der Null-Status gleich l ist. Andernfalls wird 
der nächste Befehl ausgeführt. 



In der folgenden Sequenz: 



wird der Befehl ADC $40 direkt nach dem BEQ Befehl ausgeführt, wenn der 
Null-Status gleich 1 ist. Der Befehl AND #S7F wird ausgeführt, wenn der Null- 
Status gleich 0 ist. 
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BIT - BIT-TEST 
(BIT-TEST) 

Dieser Befehl UNDiert logisch den Inhalt des Akkumulators mit dem Inhalt eines 
gewählten Speicherplatzes, setzt die Bedingungs-Fiags entsprechend, ändert 
jedoch nicht den Inhalt des Akkumulators oder des Speicherbytes. Die einzigen 
zulässigen Adressier-Arten sind absolut (direkt) und Null-Seite (direkt). Das er¬ 
ste Byte des Objektcodes bestimmt die Adressier-Art wie folgt: 



Wir wollen den BIT-Befehl unter Verwendung der absoluten (direkten) Adressie¬ 
rung illustrieren. Für den Nullseiten-Betrieb siehe den AND-Befehl und die Be¬ 
sprechung der Adressier-Arten. Wir sollten beachten, daß Bit einen ziemlich un¬ 
gewöhnlichen Einfluß auf die Status-Flags besitzt, da es das Z-Fiag entspre¬ 
chend dem Ergebnis der logischen UND-Operation setzt, jedoch die N- und 
V-Fiags entsprechend den Bits 7 und 6 des Inhalts des zu testenden Speicher¬ 
platzes setzt. Das heißt: 

Z -1 wenn AA (M)=0,Z-0 wenn A A (M) ^ 0 
N - Bit 7 von (M) 

V - Bit 6 von(M) 


Daten* 
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UNDiere logisch den Inhall des Akkumulators mit dem Inhalt des spezifizierten 
Speicherplatzesund setze das Null Fiag entsprechend Setze das Negativ- und 
Uberlaul-Ftag entsprechend den Bits 7 und 6 des gewählten Speicherplatzes Es 
sei angenommen xx = A6 16 , yy- E0, s und ppqq - 1641 |S . Nachdem der Befehl 

BIT $1641 

ausgelührt wurde, wird der Akkumulator noch A6 I6 und der Speicherplatz 
1641, G noch E0,s enthalten, die Status werden ledoch wie folgt modifiziert wor¬ 
den sein 


BMI - BRANCH IF MINUS (N = 1) 

(VERZWEIGE, WENN MINUS) 

BMI 

30 

Dieser Befehl arbeitet wie der BCC-Belehl mit der Ausnahme, daß die Verzwei¬ 
gung nur ausgelührt wird, wenn das Negativ-Flag gleich 1 ist Andernfalls wird 
der nächste Belehl ausgelührt 
In der folgenden Betehts-Sequenz 


A6 

E0 


1 0 1001 10 
f l 11 0 0 0 0 0 
10100000 


Setzt N auf 1 • ' 



Setze V aul 1 

Nicht-Null-Ergebnis setzt Z aul 0 


BIT Befehle gehen häufig bedingten Verzweigungsbelehlen voraus BIT-Belehle 
werden auch zur Auslührung von Maskier-Funklionen an Daten eingesetzt 



BEFEHL 


NÄCHSTER 
0 BEFEHL 
#$7F 


$40 


wird der Befehl ADC $40 direkt nach dem BMI-Befehl ausgeführt, wenn das 
Negaliv-Fiag gleich 1 ist Der Belehl AND #$7F wird ausgefühd. wenn das 
Negativ-Fiag 0 ist. 


BNE - BRANCH IF NOT EQUAL TO ZERO (Z = O) 

(VERZWEIGE, WENN NICHT GLEICH NULL) 

BNE 

DO 

Dieser Befehl ist identisch md dem BCD-Belehl mit der Ausnahme, daß die Ver¬ 
zweigung nur ausgelührt wird, wenn der Null-Stalus gleich 0 ist Andernfalls wird 
der nächste Belehl in der Sequenz ausgeführl 
In der folgenden Befehls-Sequenz 



NÄCHSTER 
1 BEFEHL 
#$7F 


$40 


wird der Befehl ADC $40 direkt nach dem BNE-Belehl ausgelührt. wenn der 
Null-Status gleich 1 ist Der Befehl AND #$7F wird ausgeführt, wenn der Null- 
Status 1 ist. 
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BPL- BRANCH IF PLUS (N =0) 

(VERZWEIGE, WENN PLUS) 

BPL 

10 

Dieser Befehl arbeitel wie der BCC Befehl mit der Ausnahme, daß die Verzwei¬ 
gung nur ausgeführt wird, wenn der Negativ Status 0 ist. Andernfalls wird der 
nächste Befehl in der Sequenz ausgeführt 
In der folgenden Befehls Sequenz 



NÄCHSTER 
1 BEFEHL 
#$7F 


$40 


wird der Befehl ADC $40 direkt nach dem BPL-Befehl ausgeführt, wenn das 
Negativ-Fiag 0 ist. Der Befehl AND #$7F wird ausgeführl, wenn das Negativ- 
Fiag 1 Ist. 


BRK - FORCE BREAK (TRAP OR SOFTWARE INTERRUPT) 
(ERZWINGE UNTERBRECHUNG 
- FALLE ODER SOFTWARE-UNTERBRECHUNG -) 

BKK 

00 

Der Befehlszähler wird um Zwei inkrementiert, und der Break-Status wird auf 1 
gesetzt, dann wird der Befehlszähler und das Status- (P ) Flegisler auf den Sta¬ 
pel gebracht (pushed). Die Register und die entsprechenden Speicherplätze, in 
die diese gebracht werden, sind folgende 


Speicherplatz Register 

[Stapelzeiger enthält ss am Beginn der Befehlsausführung) 

01 ss Hochwertiges Byte des Befehlszählers 

01 ss - 1 Nieder wertiges Byte des Befehlszählers 

Olss-2 Status (P-) Register mit B - 1 

(Stapelzeiger enthält ss- 3 am Ende der Befehlsausführung) 

Das Unlerbrechungsmasken Bit wird dann auf 1 gesetzt Dies sperrt die Mög¬ 
lichkeiten des 6502, Unterbrechungen zu bedienen, das heißt, der Prozessor 
wird nicht auf eine Unterbrechung von einem peripheren Baustein reagieren. 
Der Inhalt des Unterbrechungs-Zeigers (Speicher-Adressen FFFE 16 und FFFF 15 ) 
wird dann in den Befehlszähler geladen. 

Der BRK-Befehl kann für eine Vielzahl von Funktionen verwendet werden. Er lie¬ 
fert die Möglichkeit, einen Haltepunkt für Fehlersuch-Zwecke zu setzen oder er 
kann die Steuerung zu einem besonders wichtigen Software-System, wie einem 
Disketten-Betriebssystem oder einem Monitor, transfeneren. Beachten Sie, daß 
der Programmierer den erforderlichen Code einselzen muß, um einen BRK-Be- 
fehl von einer regulären Unterbrechungs-Antwort zu instruieren. Die Codierung 
hierfür prüft den Werl des B-Slalusflags im Stapel wie folgt: 

PLA ;HOLE STATUSREGISTER 

PHA ;ABER LASSE ES AUCH AUF DEM STAPEL 

AND #$10 .IST DER BREAK-STATUS GESETZT? 

BNE BRKP ,JA,FUHRE UNTERBRECHUNG AUS 

Beachten Sie, daß der Operalionscode für BRK gleich 00 ist. Diese Auswahl des 
Operationscodes bedeutet, daß BRK zum Einbringen von Programmen in 
PROMs mit Schmelzsicherungen verwendet werden kann, da das Durchschmel¬ 
zen aller Brücken den Inhalt des Wortes auf 00 bringt. Daher kann ein fehlerhaf¬ 
ter Befehl durch Änderung des ersten Objektcode-Byles auf 00 korrigiert wer¬ 
den, wodurch ein Muster über die Unterbrechungsvektor-Routine eingesetzt 
wird. Erinnern sie sich daran, daß ein Bit in einem PROM mit Schmelzbrücken 
auf 0 gesetzt werden kann (indem die Schmelzbrücke durchgeschmolzen wird), 
jedoch nicht auf 1 zurückgeselzt werden kann, wenn die Brücke durchge¬ 
schmolzen worden ist. Derartige PROMs sind nicht löschbar. 
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Die Arbeitsweise des BRK Befehls kann wie folgt illustriert werden: 



Der abschließende Inhalt des Befehlszählers ist ppqq, wobei pp den Inhalt des 
Speicherplatzes FFFF, 6 darstellt und qq den Inhalt des Speicherplatzes FFFE 16 
Beachten Sie. daß der Stapel immer auf Seite 1 des Speichers liegt, «t.ln die acht 
höchstwertigen Bits der Stapel-Adresse sind immer 01 1S . 
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BVC- BRANCH IF OVERFLOW CLEAR (V= 0) 

(VERZWEIGE, WENN ÜBERLAUF GELÖSCHT) 

_BVC_ 

50 

Oieser Belehl arbeitet wie der BCC-Belehl mit der Ausnahme, daß die 
Verzweigung nur ausgellihrt wird, wenn der Uberlaut-Status 0 ist An¬ 
dernfalls wird der nächste Befehl in der Sequenz ausgetuhrt 
Inder folgenden Belehls-Sequenz 



BEFEHL 

wird der Befehl ADC $40 direkt nach dem BVC-Befehl ausgefiihrt, wenn 
der Überlauf-Status 0 ist. Der Befehl AND #$7F wird ausgeführt, wenn 
der Überlauf-Status gleich 1 ist 


BVS- BRANCH IF OVERFLOW SET (V = 1) 

(VERZWEIGE, WENN ÜBERLAUF GESETZT) 

BVS 

70 

Dieser Befehl arbeitet wie der BCC-Befehl mit der Ausnahme, daß die Verzwei¬ 
gung nur ausgefuhrt wird, wenn der Uberlauf-Status gleich 1 ist Andernfalls wird 
der nächste Belehl in der Sequenz ausgeführt. 

In der folgenden Belehls-Sequenz 



BEFEHL 

wird der Belehl ADC $40 direkt nach dem BVS-Befehl ausgelührt, wenn der 
Ubertaul-Status gleich 1 ist Der Befehl AND #$7F wird ausgefuhrt, wenn der 
Uberlaul-Status gleich 0 ist. 
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CLC-CLEAR CARRY 

(LÖSCHE ÜBERTRAG) 

CLC 

18 

Löscht den Übertrags-Status. Kein anderer Status oder Register-Inhalt wird 
beeinflußt Beachten Sie, daß dieser Befehl als Teil der normalen Additions- 
Operation erforderlich ist, da der einzige beim Mikroprozessor 6502 verfügbare 
Additionsbefehl AOC ist, der auch den Übertrags-Status addieit Dieser Be¬ 
fehl ist also beim Beginn einer Multi-Byte-Addition erforderlich, da es niemals 
einen Übertrag in das niedrigstwertige Byte gibt. 



I I 
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CLD- CLEAR DECIMAL MODE 

(LÖSCHE DEZIMAL-BETRIEBSART) 

CLD 

D8 

Löscht den Dezimal-Betriebsart-Status. Kein anderer Status oder Register-Inhalt 
wird beeinflußt. Dieser Befehl wird zum Zurückstellen des 6502-Prozessors in 
die binäre Betriebsart veiwendet, bei der ADC und SBC-Befehle binäre anstalt 
BCD-Ergebnisse erzeugen. Dieser Befehl kann veiwendet werden um zu si- 
ohern, daß die Betriebsart in Situationen binär ist, in denen es unsicher sein 
kann, ob der Dezimalbetriebs Status kürzlich gesetzt oder gelöscht wurde 


Daten- 



F=l 
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CLI -CLEAR INTERRUPT MASK (ENABLE INTERRUPTS) 
(LÖSCHE UNTERBRECHUNGS-MASKE 
-GIB UNTERBRECHUNGEN FREI -) 



Löscht das Unterbrechungs-Maskenbit im Status- (P-) Register. Dieser Befehl 
gibt die Unterbrechungs-Möglichkeil des 6502 frei, d.h., der 6502 wird auf die 
Unterbrechungs-Anforderungs-Steuerleilung reagieren. Es werden keine weite¬ 
ren Register oder Status beeinflußt. Beachten Sie, daß das I-Bit eine Maske 
oder ein Sperr-Bit ist. Es muß gelöscht werden, um Unterbrechungen freizuge¬ 
ben, und gesetzt werden, um sie zu sperren. 


Daten- 
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CLV - CLEAR OVERFLOW 
(LÖSCHE ÜBERLAUF) 

CLV 



Löscht das Überlauf Bit im Status Register. Keine anderen Register oder Status 
werden beeinflußt. Beachten Sie, daß der 6502 keinen Befehl für SET OVER¬ 
FLOW (Setze Überlauf) besitzt. 


Daten- 
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CMP- COMP ARE MEMORY WITH ACCUMULATOR 

(VERGLEICHE SPEICHER MIT AKKUMULATOR) 

Dieser Befehl subtrahierl den Inhalt des gewählten Speicher-Bytes vom Akku¬ 
mulator. setzt die Bedingungs-Flags entsprechend, beeinflußt jedoch nicht den 
Inhalt des Akkumulators oder des Speicher-Bytes. Dieser Befehl bietet die glei¬ 
chen Speicher-Adressier-Oplionen wie der ADC-Befehl. Das erste Byte des Ob- 
tektkodes wählt die Adressier-Art wie folgt: 


76513210 • 
|l|l|0]a| a |a|0lll 


-Bti Number 

►Obiect Code 


Bit-Wert 
für aaa 

Hexadezimaler 

Obiekt-Code 

Adressier-Arl 

Anzahl 
der Bytes 

000 

CI 

Indirekt, vor-indiziert mit X 

2 

001 

C5 

Null-Seite (direkt) 

2 

010 

C9 

Unmittelbar 

2 

01 1 

CD 

Absolut (direkt) 

3 

100 

Dl 

Indirekt, nach-indiziert mit Y 

2 

101 

D5 

Null-Seite indiziert mit X 

2 

110 

D9 

Absolut indiziert mit Y 

3 

111 

DD 

Absolut indiziert mit X 

3 


Wir wollen den CMP-Befehl mit vor-indizierter indirekter Adressierung (unter 
Verwendung des Indexregisters X) illustrieren. Schlagen Sie die Besprechung 
der Adressier Arten und der anderen Befehle für Beispiele weiterer Adressier- 
Arten nach 

Daten- 



Subtrahiere den Inhalt des gewählten Speicher Bytes vom Inhalt des Akkumula¬ 
tors und setze den Negativ-, Null- und Übertrags-Status, um das Ergebnis der 
Subtraktion wiederzugeben. Es sei angenommen xx- FF, 6 . yy=18m, rr-20,6. 
cc- 23 1b , (0043, 6 ) = GD,6 und (0044 1G ) = 15,«. Beachten Sie, daß 0043 - rr + 
cc und wir angenommen haben, daß (15GD, 6 )- yy - 18,«. 
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Nachdem der Befehl 


CMP (S23.X) 

ausgefuhrl wurde, wird der Akkumulator noch F6 16 und der Speicherplatz 
1 56D,« noch 18, 6 enthalten, die Status werden ledoch wie folgt geändert sein: 


F6 = 11110 110 
Zweierkomplement von 18 = 1110100 0 


Selzt C auf 1 
Setzt N aul 1 



Nicht-Nuil-Ergebms setzt 

Z auf 0 


Beachten Sie, daß C gleich dem sich ergebenden Übertrag ist, und nicht seinem 
Komplement, wie es für manche andere Mikroprozessoren gilt. Daher 
isl C - 0. wenn ein Borgen 1 ' erforderlich ist, und C » 1 wenn kein Borgen erfor¬ 
derlich war. 

Vergleichs-Befehle werden häutig zum Setzen von Status vor der Ausführung 
von bedingten Verzweigungs-Befehlen verwendet 
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CPX - COMPARE INDEX REGISTER X WITH MEMORY 

(VERGLEICHE INDEXREGISTER X MIT SPEICHER) 

Dieser Befehl ist der gleiche wie CMP mi! der Ausnahme, da8 das Speicherbyte 
vom Indexregister X anstatt vom Akkumulator subtrahieit wird. Die einzigen zu- 
tassigen Adressier Arten sind die unmittelbare, Nuli-Seiten- (direkte) und abso¬ 
lute (direkte) Adressierung Das erste Byte des Obiektcodes wählt die Adres* 
Sier-Art wie folgt 


7 6 5 4 3 2 1 0- 

|i h h Io |c |c Io |oh 


■ 0t»)9kt*Code 


Bit-Wert 
für aaa 

Hexadezimaler 

Objekt-Code 

Adressier-Art 

Anzahl 
der Bytes 

00 

EO 

Unmittelbar 

2 

01 

E4 

Null-Seite (direkt) 

2 

10 


Verwendet tur INX-Befehl 


11 

EC 

Absolut (direkt) 

3 


Wir wollen den CPX Befehlt mit unmittelbarer Adressierung illustrieren Schlagen 
Sie die Besprechung der Adressier-Arten und weitere arithmetische und logi¬ 
sche Befehle für Beispiele der übrigen Adressier-Arten nach 

Daten- 



Subtrahiere den Inhalt des gewählten Speicherbytes vom Inhalt des Indexregi¬ 
sters X Der Negativ-, Null- und Übertrags-Status gibt das Ergebnis der Subtrak¬ 
tion in gleicher Weise wieder, wie für den CMP-Befehl gezeigt wurde 
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CPY-COMPARE INDEX REGISTER Y WITH MEMORY 

(VERGLEICHE INDEXREGISTER Y MIT SPEICHER) 

Dieser Belehl ist der gleiche wie CMP mit der Ausnahme, daß das Speicherbyte 
vom Indexregister Y anstatt vom Akkumulator subtrahiert wird Die einzigen zu¬ 
lässigen Adressier-Arten sind die unmittelbare, Nutl-Seiten- (direkte) und abso¬ 
lute (direkte) Adressierung Das erste Byte des Objektcodes wählt die Adres¬ 
sier Art wie folgt 


7 6 5 4 3 2 10 . 
|l I 1 | 0 | 0 |c |c |« tk 


Bit-Wert 
für aaa 

Hexadezimaler 

Obtekt-Code 

Adressier-Art 

Anzahl 
der Bytes 

00 

CO 

Unmittelbar 

2 

01 

C4 

Nult-Seite (direkt) 

2 

10 


Verwendet für tNY-Befehl 


11 

CC 

Absolut (direkt) 

3 


Wir wollen den CPY-Befehl mit Nuii-Seiten- (direkter) Adressierung illustrieren. 
Schlagen Sie die Besprechung der Adressier-Arten und weitere arithmetische 
und logische Befehle für Beispiele der anderen Adressier-Arten nach. 


Daten- 



Subtrahiere den Inhalt des gewählten Speicherbytes vom Inhalt des Indexregi¬ 
sters Y. Das Negativ-, Null- und Ubertrags-Ftag geben das Ergebnis der Sub¬ 
traktion auf die gleiche Weise wieder, wie für den CMP-Befeht gezeigt wurde 
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DEC - DECREMENT MEMORY (BY 1) 

(DEKREMENTIERE SPEICHER (UM 1)) 

Dieser Befehl dekrementiert den Inhalt des gewählten Speicherplatzes um 1 
Der DEC-Befehl verwendet vier Möglichkeiten der Datenspeicher-Adressierung: 

1) Null-Seite (direkt) - DEC addr 

2) Absolut (direkt) - DEC addrl 6 

3) Null-Seite indiziert mit Indexregister X - iEC addr,X 

4) Absolut indiziert mit Indexregister X - DEC addrlS.X 

Das erste Byte des •bjektcodes bestimmt die gewählte Adressier-Art wie folgt: 



Wir wollen den DEC-Befehl mit absoluter indizierter Adressierung zeigen. Sie 
anderen Adressier-Arten sind an anderer Stelle zu finden. 


Daten- 
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Dekrementiere den Inhalt des spezifizierten Speicherbytes, 

Wenn yy- A5, 6| ppqq - 01 00 l6 und rr . tA«, dann wird nach der Ausführung 
des Befehls 

DEC S0100.X 

der Inhalt des Speicherplatzes 010A 16 auf A4 16 geändert. 


Ah 

Einer-Komplement von 1 

Übertrag wird nicht 
geändert 


10100101 

11111111 


10100100 

I L 


Nicht-Null-Ergebnis setzt Z auf 0 



Überlauf (V) wird nicht geändert 
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DEX - DECREMENT INDEX REGISTER X (BY 1) 

(DEKREMENTIERE INDEXREGISTER X (UM 1» 

Dieser Befehl dekrementiert den Inhalt des Indexregisters X um 1. Der Null-und 
Negativ-Status werden beeinflußt, 

OEX 



Die Auswirkungen dieses Befehls sind die gleichen wie iene von DEC mit der 
Ausnahme, daß der Inhalt des Indexregisters X dekrementiert wird, anstatt der 
Inhalt eines Speicherplatzes, 


Daien- 
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DEY- DECREMENT INDEX REGISTER Y (BY 1) 

(DEKREMENTIERE INDEXREGISTER Y (UM 1)) 

Dieser Befehl dekrementiert den Inhalt des Indexregisters Y um 1. Der Null- und 
Negativ-Status werden beeinflußt, s* wie dies bei DEC und DEX der Fall war. 


DEY 
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EOR - EXCLUSIVE-OR ACCUMULATOR WITH MEMORY 

(EXKLUSIV-ODERiere AKKUMULATOR MIT SPEICHER) 

Bildei das logische Exklusiv-ODER des Inhalts des Akkumulators mit dem Inhalt 
eines gewählten Speicherbyles, Dieser Belehl bietet die gleichen Adres- 
sier-Oplionen wie der ADC-Belehl. Das erste Byte des Objektcodes wählt die 
Adressier-Arl wie folgt: 



Wir wollen den EOR-Befehl mit nach-indizierler. indirekter Adressierung (unter 
Verwendung des Indexregisters Y) illustrieren Schlagen Sie die Besprechung 
der Adressier-Arten und anderer arithmetischer und logischer Befehle lür Bei¬ 
spiele der anderen Adressier-Arten nach. 
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Exklusiv-ODERiere logisch den Inhalt des Akkumulators mit dem Inhalt des ge¬ 
wählten Speicherplatzes, wobei beide Operanden als einfache Binardaten be¬ 
handelt werden Es sei angenommen, daß »x - 43 )6 und yy = AOi«. Nachdem der 
Belehl 

EOR ($40.Y) 

ausgefuhrt wurde, wird der Akkumulator 43i S enthalten. Wir nehmen auch an, 
daß rr-10,8, «iq— (40,s) - 1 E ie . pp - (41, s )=25i« und (25lE, s ) = yy- A0, e . 


E3 - 1 1 10 00 1 1 
A0 = 10100000 
01000011 


0 setzt N auf 0 



I—»-Nichl-Nuii-Ergebnis setzt Z auf 0 


EOR wird zum Testen aul Änderungen des Bit-Status verwendet. Beachten Sie 
auch, daß der Befehl EOR #$FF den Inhalt des Akkumulators komplementiert, 
wobei er jedes 1 Bit in eine 0 und jedes 0-Bil in eine 1 verwandelt. 
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INC - INCREMENT MEMORY (BY 1) 

(INKREMENTIERE SPEICHER (UM 1)) 

Dieser Befehl inkremenliert den Inhall eines gewählten Speicherplalzes um ] 
Der INC Befehl verwendet vier Arien der Datenspeicher-Adressierung: 

1) Nuli-Seile (direkt)-INC addr 

2) Absolut (direkt) -INC addr16 

3) Null-Seile indiziert mit Indexregister X- INC addr.X 

4) Absolut indiziert mit Indexregister X -INC addrie.X 

Das erste Byte des Objektcodes bestimmt wie folgt, welche Adressier Art ge¬ 
wählt wurde - 


7 6 5 4 3 2 1 0 ^ Bil-Nummer 

1 1 |l I I |b |d 1 1 i l loK ^-Objekt-Code 


Bit Werl 
für aaa 

Hexadezimaler 

Obiekl-Code 

Adressier-Art 

Anzahl 
der Bytes 

00 

E6 

Null-Seite (direkt) 

2 

01 

EE 

Absolut (direkt) 

3 

10 

F6 

Null-Seite indiziert mit X 

2 

11 

FE 

Absolut indiziert mit X 

3 


Wir wollen den INC-Befehl mit absoluter (direkter) Adressierung illustrieren Die 
übrigen Adressier-Arten sind an anderer Stelle gezeigt. 


Daten- 



mmmm 
mmmm • ) 
(TVTVTtm ♦ 2 
mmmm ♦ 3 


Inkrementiere das gewählte Speicherbyle 

Wenn pp = 01,6. m=A 2, 6 und yy = C0, s . dann wird nach der Ausführung 
eines Befehls 


INC S01A2 

der Inhalt des Speicherplatzes 01A2, s auf Cl, 6 mkrementiert. 

CO = 1 1 000000 
1 = 00000001 
11000001 

I—»-Nichl-Null-Ergebnis setzt Zauf 0 

Übertrag und Überlauf werden 
nicht beeinflußt 


Setzt N auf 1 


Der INC-Befehl kann zur Bildung eines Zahlers in einer Vielzahl von Anwendun¬ 
gen eingesetzt werden, wie etwa das Zählen der Häufigkeit des Auftre¬ 
tens eines Vorganges oder des Spezifizierens, wie oft eine entsprechende Auf¬ 
gabe auszuführen ist 
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INX - INCREMENT INDEX REGISTER X (BY 1) 

(INKREMENTIERE INDEXREGISTER X (UM 1)) 

Dieser Befehl inkrementiert den Inhalt des Indexregisters X um 1 Der Null- und 
Negativ-Status werden so wie beim INC-Befehl beeinflußt. 



N V B D I Z C 



Daten¬ 

speicher 


mmmm 
mmrrifn ♦ 1 


Programm- 
I Speicher 


E8 


Addiere 1 zum Inhalt des Indexregisters X und setze die Null- und Negativ-Flags 
entsprechend dem Ergebnis. Es sei angenommen, daß das Indexregister X den 
Wert 7A,e enthält. Nachdem der Befehl 

INX 

ausgeführt wurde, wird das Indexregister 7B, S enthalten, der Null-Status wird 
gelöscht werden, da das Ergebnis nicht Null ist, und der Negativ-Status wird ge¬ 
löscht sein, da das Ergebnis 0 in seinem höchstwertigen Bit enthält. 


INY - INCREMENT INDEX REGISTER Y (BY 1) 

(INKREMENTIERE INDEXREGISTER Y (UM 1)) 

Dieser Befehl inkrementiert den Inhalt des Indexregisters Y um 1 Der Null- und 
Negativ-Status werden so wie beim INC Befehl beeinflußt. 



n v b o i z c 
p |*l MINI 



Oalerv 

Speicher 


mmmm 
mmmm♦ i 


F'ropramm- 
| Speicher | 


C8 


Addiere 1 zum Inhalt des Indexregisters Y und setze das Null- und Negativ- 
Flag entsprechend dem Ergebnis. Es sei angenommen, daß das Indexregister Y 
den Wert OCi S enthält. Nachdem der Befehl INY ausgetührt wurde, wird das In¬ 
dexregister Y den Wert 0D I6 enthalten, der Null-Status wird gelöscht sein, da 
das Ergebnis nicht Null ist, und der Negativ-Status wird gelöscht sein, da das 
Ergebnis 0 in seinem höchstwertigen Bit besitzt. 
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JMP-JUMP VIA ABSOLUTE OR INDIRECT ADDRESSING 

(SPRINGE MITTELS ABSOLUTER ODER INDIREKTER 
ADRESSIERUNG) 

Dieser Befehl wird unter Verwendung der indirekten Adressierung illustriert wer¬ 
den Beachten Sie. daß es der einzige Befehl ist, der die echte indirekte Adres¬ 
sierung besitzt Das erste Byte des Objeklcodes bestimmt die Adressier-Art wie 
folgt: 


7 6 S 4 3 1 1 Q i 

loh [ y 10 M I 1 101 0 


Bit-Nummer 

Objekt-Code 


Bit-Wert 
für y 

Hexadezimaler 

Obtekt-Code 

Adressier-Art 

Anzahl 
der Bytes 

0 

4C 

Absolut (direkt) 

3 

1 

6C 

Indirekt 

3 


N V B D I Z C 


pH 



Daten¬ 

speicher 


ccdd 
ccdd-f 1 


Programm¬ 

speicher 


dd 


mOhmm 
mmmm♦ 1 
mm mm 2 


Spnnge zu dem Befehl, der durch den Operanden spezifizieitwird, durch Laden 
der Adresse von den gewählten Speicherbyles in den Befehlszähler. 

In der folgenden Befehls-Sequenz 


Clc 

LDA *BASEL .BERECHNE LSBS DER BESTIMMUNGS ADRESSE 
ADC INDXL 

STA JADDR 

LDA * BASEU .BERECHNE MSBS DER BESTIMMUNGS ADRESSE 

ADC INDXU 

STA JADDR+1 

JMP (JADDR) .TRANSFERIERE STEUERUNG ZUR ZIEL-ADRESSE 


Der JMP-Befehl wird einen indizierten Sprung relativ zur 16-Bit Adresse ausfüh¬ 
ren, die aus BASEU (8 MSBs) und BASEL (8 LSBs) besteht Es wird hier ange 
nommen. daß der Index 16 Bits lang ist und anfangs bei den Adressen INDXL (8 
LSBs) und INDXU (8 MSBs) gespeichert ist Die Adressen, die dem Beginn der 
Tabelle folgen, kannten dann absolute JMP Befehle enthalten, die die Steuerung 
zu den entsprechenden Routinen transfeneren 

Der JMP-Befehl kann auch die absolute (direkte) Adressier-Art verwenden In 
diesem Fall wird das zweite Byte des Befehls in das mederwerlige Byte des Be- 
lehtszahfers und das dnlte Byte des Befehls in das höherwertige Byte des Be¬ 
fehlszählers geladen. Die Befehlsausführung wird von dieser Adresse ab fortge¬ 
setzt 


3-72 


3-73 





JSR - JUMP TO SUBROUTINE 

(SPRINGE ZU UNTERPROGRAMM) 

Dieser Befehl bringt den Inhalt des Befehlszählers auf den Stapel und 
überträgt dann die Steuerung dem spezifizierten Befehl. Es ist nur abso¬ 
lute (direkte) Adressierung gestattet. Beachten Sie, daß der Stapelzeiger nach 
der Speicherung jedes Datenbytes inkrementiert wird und daß der Wert des Be¬ 
fehlszählers, der aufbewahrt wird, die Adresse des letzten (dritten) Bytes des 
JSR-Befehls darstellt, das heißt, der anfängliche Wert des Befehlszählers plus 2. 
Erinnern Sie sich auch daran, daß der Stapel im Speicher abwärts wächst und 
daß die höchstwertige Hälfte des Befehlszählers zuerst gespeichert wird und 
daher bei der höheren Adresse endet (in der gewöhnlichen Adressier- 
Form des 6502). 


Daten- 



Der Befehlszähler wird um 2 inkrementiert und dann auf den Stapel ge¬ 
bracht. Der Stapelzeiger wird so eingerichtet, daß er zum nächsten lee¬ 
ren Speicherplatz im Stapel zeigt. Der Adressen-Teil des Befehls wird 
dann in den Befehlszähler gespeichert und die Ausführung wird ab die¬ 
sem Punkt fortgesetzt. 

Es sei angenommen mmmm - E34F 16 und ss - E3 16 . Dann wird nach der 
Ausführung des Befehls 


JSR SEI 00 

der Befelszähler den Wert E100 1S enthalten, der Stapelzeiger wird E1 16 
enthalten und die Stapelplätze werden wie folgt lauten: 

(01ss) = (01E3)= PC(HI) = E3 
(01 ss — 1) = (01 E2) = PC(LO) = 51 16 

Der nächste auszuführende Befehl wird derjenige bei der Speicher-Adresse 
El 00 16 sein. 


LDA - LOAD ACCUMULATOR FROM MEMORY 

(LADE DEN AKKUMULATOR VOM SPEICHER) 

Lädt den Inhalt des gewählten Speicherbytes in den Akkumulator. Die¬ 
ser Befehl bietet die gleichen Speicher-Adressiermöglichkeiten, wie der 
ADC-Befehl und wird unter Verwendung der indizierten Nullseiten-Adressierung 
mit dem Indexregister X illustriert. Schlagen Sie die Besprechung der Adressier- 
Arten und der anderen arithmetischen und logischen Befehle für Beispiele der 
übrigen Adressier-Arten nach. Das erste Byte des Objektcodes wählt die Adres- 
sier-Art wie folgt: 


7 6 5 4 3 2 1 0 ^ Bit-Nummer 

|l | 0 11 [ a | a | a 10 [ 1 [) ^ Objekt-Code 


Bit-Wert 
für aaa 

Hexadezimaler 

Objekt-Code 

Adressier-Art 

Anzahl 
der Bytes 

000 

AI 

Indirekt, vor-indiziert mit X 

2 

001 

A5 

Null-Seite (direkt) 

2 

010 

A9 

Unmittelbar 

2 

011 

AD 

Absolut (direkt) 

3 

100 

Bl 

Indirekt, nach-indiziert mit Y 

2 

101 

B5 

Null-Seite indiziert mit X 

2 

110 

B9 

Absolut indiziert mit Y 

3 

111 

BD 

Absolut indiziert mit X 

3 


Daten- 



OOrr + cc 


mmmm 
mmmm + 


i 
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Lade den Inhalt des gewählten Speicherbyles in den Akkumulator. 

Es sei angenommen, daß das Indexregister X den Werl 10 1S enthält und cc - 
43 is . Wenn der Speicherplatz 0053 1S den Wert AA 16 enthält, dann wird nach 
Ausführung von 

LDA $43,X 

der Akkumulator den Werl AAig enthalten 


AA 

1 setzt N aut 1 


= I U I U I U I u 

_J L 


Nicht Null-Ergebnis setzt Zauf 0 
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Lbx - LÖAD INDEX REGISTER X FROM MEMORY 
(LADE INDEXREGISTER X VOM SPEICHER) 

Ladt den Inhalt des gewählten Speicherbyles in das Indexregister X Die zulässi¬ 
gen Adressier-Arten sind: 

1) Unmittelbar-LDX data 

2) Absolut (direkt)- LDX addrlß 

3) Null-Seile (direkt)-LDX addr 

4) Absolut indiziert mit Y - LDX addrlß,Y 

5) Null-Seile indiziert mit Y - LDX addr.Y 

Beachten Sie. daß es keine indizierten Adressier-Arten mit dem Indexregister X 
gibt, sowie keine Nach Indizierung 

Das erste Byle des Objeklcodes wählt die Adressier Art wie tolgt 


76543210 - 

tiioliId|dIdhloL 


Bil-NumnWr 

Objekt-Cod« 


Bit-Wert 
für aaa 

Hexadezimaler 
Obiekt Code 

Adressier-Arl 

Anzahl 
der Bytes 

000 

A2 

Unmittelbar 

2 

001 

Aß 

Null-Seite (direkt) 

2 

010 

AA 

Verwendet furTAX-Befehl 


011 

AE 

Absolut (direkt) 

3 

100 

B2 

Nicht verwendet 


101 

B6 

Null-Seile indiziert mit Y 

2 

110 

BA 

Verwendet tür TSX-Befehl 


111 

BE 

Absolut indiziert mit Y 

3 


Wir wollen den LDX Befehl mit absoluler indizierter Adressierung unter Verwen¬ 
dung des Indexregisters Y illustrieren. Schlagen Sie die Besprechung der 
Adressier-Arten und anderer arithmetischer und logischer Betehle tür Beispiele 
der übrigen Adressrer-Arten nach. 

Dalen- 
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Lade den Inhalt des gewählten Speicherbytes in das Indexregister X. Es sei an¬ 
genommen, daß das Indexregister V den Wert 28,» enthält, ppqq - 2E1A, 6 und 
yy-(2E42 ls )= 4F,,. Dann wird nach der Austührung des Betehls 

LDX S3E1A.Y 

das Indexregister X den Wert 4F,« enthalten. 


4F 

0 setzt N aut 0 


= 01001111 

_J L 


Nicht-Null-Ergebms setzt 2 aut 0 


LDY - LOAD INDEX REGISTER Y FROM MEMORY 
(LADE INDEXREGISTER Y VOM SPEICHER) 

Lädt den Inhalt des gewählten Speicherbytes in das Indexregister Y. Die zulässi¬ 
gen Adressier-Arten sind: 

1) Unmittelbar-LDY data 

2) Absolut (direkt) - LDY addrt 6 

3) Nulf-Seite (direkt) - LDY addr 

4) Absolut indiziert mit X - LDY addrtß.X 

5) Nuil-Seite indiziert mit X - LDY addr.X 

Beachten Sie, daß es weder indizierte Adressier-Arten mit dem Indexregister Y 
gibt, noch irgendwelche Vor-lndi 2 ierung. 

Das erste Byte des Objektcodes wählt die Adressier-Art wie tolgt: 


7 s s 4 3 z i o. 


Bit-Nummer 

Objekt-Code 


Bit-Wert 
für ddd 

Hexa¬ 
dezimaler 
Objekt Code 

Adressier-Ait 

Anzahl 
der Bytes 

000 

A0 

Unmittelbar 

2 

001 

A4 

Nuil-Seite (direkt) 

2 

010 

A8 

Verwendet für TAY-Betehl 


011 

AC 

Absolut (direkt) 

3 

100 

60 

Verwendet für BCS-Befehl 


101 

64 

Nuil-Seite indiziert durch X 

2 

110 

66 

Verwendet für CLV-Belehl 


111 

6C 

Absolut indiziert durch X 

3 


Wir wollen den LDY-Befehl mit unmittelbarer Adressierung illustrieren Schlagen 
Sie die Besprechung der Adressier-Arten und anderer arithmetischer und logi¬ 
scher Betehle für Beispiele der übrigen Adressier-Arten nach 


NVBDIZC 

MilJ 11 L*l„l 


Daten¬ 

speicher 
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Lade den Inhalt des gewählten Speicherbytes in das Indexregister Y. Es sei an¬ 
genommen, daß yy-OO tSl so daß nach der Austührung des Befehls 

LDY #0 

das Indexregister Y den Wert 0 enthalten wird. 


00 

0 setzt N aut 0 


00000000 

J L 


Null-Ergebnis setzt Z aut 1 


LSR - LOGICAL SHIFT RIGHT OF ACCUMULATOR OR 
MEMORY 

(LOGISCHE RECHTS-VERSCHIEBUNG DES 
AKKUMULATORS ODER SPEICHERS) 

Dieser Befehl tührt eine logische Rechts-Verschiebung um ein Bit des Akkumu¬ 
lators oder des gewählten Speicherbyles aus. 

Zuerst sei die Verschiebung des Akkumulators betrachtet. 

LSR A 

4A 


N V B D I Z C 



Qat«n- 

Soetche* 


Programm. 

Speicher 


mrntnrri 
mmmm ♦ | 


Schiebe den Inhalt des Akkumulators um ein Bit nach rechts. Schiebe das 
niederwerlige Bit in den Übertrags Status. Schiebe eine Null in das hochwertige 

Bit. 

Der Akkumulator enthalte angenommen 7A| 6 . Nachdem der Belehl 

LSR A 

ausgetühil wurde, wird der Akkumulator den Wert 3D, a enthalten und der Über¬ 
tragungs-Status wird aut Null gesetzt sein. 

Akkumulator Übertrag 

011110 1 0—•- X 
00111101 0 

I 

-I '— - Nicht-Null-Ergebnis setzt Z auf 0 


LSR setzt N immer 
auf 0 
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Vier Arten der Adressierung des Datenspeichers sind mit dem LSR-Betehl v/er- 
tügbar. Diese sind: 

1) Null-Seile (direkt) - LSR addr 

2) Absolut (direkt)- LSR addr16 

3) Null-Seile indiziert mit Indexregister X - LSR addr.X 

4) Absolut indizieil mit Indexregister X - LSR addr16,X 

Das erste Byte des Objektcodes bestimmt die gewählte Adressier-Arl wie folgt: 



Wir wollen den LSR-Befehl mit absoluter (direkter) Adressierung illustrieren. Die 
übrigen Adressier-Arten sind anderweitig gezeigt. 
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Verschiebe den Inhalt des gewählten Speicherbyles logisch um ein Bit nach 
rechts. 

Es sei angenommen ppqq - 04FA 1S und der Inhalt des Speicherplatzes 04FAi« 
sei ODie. Nachdem der Betehl 

LSR S04FA 

ausgetührl wurde, wird der Überlags Status 1 sein und der Inhalt des Speicher¬ 
platzes 04FA 1S wird 06 i 9 sein. 


0 

LSR setzt N immer aut 0- 


l04FAiß) Übertrag 

0000 1 1 0 1- -x 

00000110 1 

J I _ Nichl-Null-Ergebnis setzt 2 auf 0 
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NOP-NO OPERATION 

(KEINE OPERATION) 

NOP 

EA 

Dies ist ein Ein-Byte-Befehl, der nichts weiter ausführt, als den Befehlszähler zu 
inkrementieren Dieser Befehl gestattet Ihnen, eine Markierung (labei) einem 
Objektprogramm-Byte zu geben, odereine Verzögerung fein einzustellen (jeder 
NOP-Befehl addieit zwei Taktzyklen) und Befehls-Bytes zu ersetzen, die nicht 
langer infolge von Korrekturen oder Änderungen erforderlich sind. NOPs kön¬ 
nen auch zum Ersetzen von Befehlen (wie etwa JSRs) verwendet wer¬ 
den, die Sie vielleicht in Fehlersuch-Läuten nicht wollen. NOP wird nicht sehr 
häufig in endgültigen Programmen verwendet, ist jedoch häufig bei der Fehler¬ 
suche und beim Testen von Nutzen. 


Daien- 
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OR A- LOGICALLY OR MEMORY WITH ACCUMULATOR 

(ODERiere SPEICHER MIT AKKUMULATOR LOGISCH) 

Dieser Befehl ODERiert logisch den Inhalt eines Speicherplatzes mit dem Inhalt 
des Akkumulators Dieser Befehl bietet die gleichen Speicher-Adres- 
siermoglichkeiten wie der ADC-Befehl Das erste Byte des Objektcodes 
wählt die Adressier-Art wie folgt: 


7 6 5 4 3 2 10« 
|o|o|Q)a |a |a | 0 | 1 I- 


- Bit-Nümrrer 
• Objekt-Code 


Bit-Wert 
lür aaa 

Hexadezimaler 

Objekt-Code 

Adressier-Art 

Anzahl 
der Bytes 

000 

01 

Indirekt, vor-indiziert mit X 

2 

001 

05 

Null-Seite (direkt) 

2 

010 

09 

Unmittelbar 

2 

011 

OD 

Absolut (direkt) 

3 

100 

11 

Indirekt, nach-indiziert mit Y 

2 

101 

15 

Null Seite indiziert mit X 

2 

110 

19 

Absolut indiziert mit Y 

3 

111 

10 

Absolut indiziert mit X 

3 


Wir wollen den ORA-Belehl unter Verwendung der absoluten indizierten Adres¬ 
sierung mit dem Indexregister Y illustrieren. Schlagen Sie die Besprechung der 
Adressier-Arten und anderer arithmetischer und logischer Befehle für Beispiele 
für die übrigen Adressier-Arten nach 



ODERiere logisch den Inhalt des Akkumulators mit dem Inhalt des gewählten 
Speicherbytes, wobei beide Operanden als einfache Binardaten behandelt wer¬ 
den. 
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Es sei angenommen ppqq - 1623 l6 , rr-10 ls , xx=E3i 6 und yy-AB ls , Nach 
Ausführung des Befehls 


ORA S1623.1Y 

wird der Akkumulator EB 16 enthalten. 


E3 

AB 


Setzt in auf 1 


11100011 

10101011 

11101011 



Nicht-Nuii-Ergebnis setzt Z auf 0 


Dies ist ein logischer Befehl, der häulig zum "Ein'-Schalten von Bits verwendet 
wird, das heißt, sie auf 1 zu setzen. Beispielsweise wird der Befehl 

ORA #$ao 

das hochwertige Bit im Akkumulator ohne Bedingung auf 1 setzen. 


PHA - PUSH AKKUMULATOR ONTO STACK 

(BRINGE AKKUMULATOR AUF DEN STAPEL) 

Dieser Befehl speichert den Inhalt des Akkumulators auf die Spitze des Stapels. 
Der Stapelzeiger wird dann um 1 dekrementiert. Es werden keine weiteren Regi¬ 
ster oder Status beeinflußt. Beachten Sie, daß der Akkumulator in den Stapel ge¬ 
speichert wird, bevor der Stapelzeiger dekrementiert wird. 

PHA 

48 


Daten- 



Der Akkumulator enthalte angenommen 3A IS und der Stapelzeiger F7 16 . Nach¬ 
dem der Befehl PHA ausgeführt wurde, wird 3 Ai 6 in den Speicherplatz 01F7 le 
gespeichert und der Stapelzeiger auf F6«; geändert worden sein. 

Der PHA-Befehl wird am häufigsten zur Aufbewahrung des Akkumulator-Inhal¬ 
tes verwendet, bevor eine Unterbrechung bedient oder ein Unterprogramm auf¬ 
gerufen wird. 
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PHP- PUSH STATUS REGISTER (P) ONTO STACK 

(BRINGE STATUSREGISTER (P) AUF DEN STAPEL) 

Dieser Befehl speichert den Inhalt des Statusregisters (P) auf die Spitze des Sta¬ 
pels. Der Stapelzeiger wird dann um 1 dekrementiert. Es werden keine anderen 
Register oder Status beeinflußt. Beachten Sie, daß das Statusregister in den Sta¬ 
pel gespeichert wird, bevor der Stapelzeiger dekrementiert wird. 

Die Organisation des Status im Speicher ist wie folgt: 

7 6 5 4 3 2 1 0^-Bit-Nummer 

ISFnBMnzTcH — Register P 

Bit 5 wird nicht verwendet und sein Wert ist willkürlich. 

PHP 



Der PHP-Befehl wird im allgemeinen zur Aufbewahrung des Inhalts des Status¬ 
registers vor dem Aufrufen eines Unterprogramms verwendet. Beachten Sie, 
daß PHP nicht erforderlich ist, bevor eineJJnterbrechung bedient wird, da die 
Unterbrechungs-Reaktion (auf IRQ oder NM1) und der BRK-Betehl automatisch 
den Inhalt des Statusregisters an der Spitze des Stapels aufbewahren. 
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PLA - PULL CONTENTS OF ACCUMULATOR FROM STACK 
(HOLE INHALT DES AKKUMULATORS VOM STAPEL) 


Dieser Befehl inkrementiert den Stapelzeiger um 1 und lädt dann den Akkumula¬ 
tor von der Spitze des Stapels. Beachten Sie, daß der Stapelzeiger vor dem La¬ 
den des Akkumulators inkrementiert wird. 



DerStapelzeiger enthalte angenommen F6, s , und der Speicherplatz 01F7, 6 ent¬ 
halte CE, 6 . Nach der Ausführung des PLA-Befehls wird der Akkumulator CE 16 
und der Stapelzeiger F7 1S enthalten. 


F7 = 11110 111 


Setzt N auf 1 • 


■ Nicht-Nuii-Ergebnis setzt 2 auf 0 


Der PLA-Befehl wird am häufigsten zur Zurückspeicherung des Akkumulator- 
tnhaltes verwendet, der auf den Stapel gerettet wurde, z.B. nach der Bedienung 
einer Unterbrechung oder nach dem Abschluß eines Unterprogramms. 
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PLP- PULL CONTENTS OF STATUS REGISTER (P) FROM 
STACK 

(HOLE INHALT DES STATUSREGISTERS (P) VOM 
STAPEL) 

Dieser Befehl inkrementiert den Stapelzeiger um 1 und lädt dann das Statusregi¬ 
ster (P) von der Spitze des Stapels. Es werden keine anderen Register beein¬ 
flußt, es können jedoch alle Status geändert werden. Beachten Sie, daß der Sta¬ 
pelzeiger vor dem Laden des Statusregisters inkrementiert wird. 

PI P 

28 

Die Organisation des Status im Speicher sieht wie folgt aus: 


7 6 5 4 3 2 1 0 -* 
|N|V| IB | D 1 I [Z Ic)- 


--Bil-Nummer 
— Register P 


Bit 5 wird nicht verwendet. 


Oaterv 



Der PLP-Befehl wird im allgemeinen zum Zurückspeichern des Inhalts des Sta¬ 
tusregisters nach Abschluß eines Unterprogramms verwendet. Daher dient er 
zum Ausgleich des früher erwähnten PHP-Befehls. Beachten Sie, daß PLP nach 
der Bedienung einer Unterbrechung nicht erforderlich ist, da der RTf-Befehl 
automatisch den Inhalt des Statusregisters von der Spitze des Stapels zurück¬ 
speichert 
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ROL- ROTATE ACCUMULATOR OR MEMORY LEFT 
THROUGH CARRY 

(ROTIERE AKKUMULATOR ODER SPEICHER NACH 
LINKS DURCH DEN ÜBERTRAG) 

Dieser Befehl rotiert den Akkumulator oder das gewählte Speicherbyte um ein 
Bit nach links durch den Übertrag 

Zuerst sei die Rotalion des Akkumulators betrachtet. 


ROL A 



Rotiere den Inhalt des Akkumulators um ein Bit nach links durch den Übeitrags- 
Status. 

Der Akkumulator enthalte angenommen 7A tS , und der Übertrags-Status wird auf 
1 gesetzt. Nachdem der Befehl 

ROL A 


ausgeführt wurde, wird der Akkumulator F5, 6 enthalten, und der Übertrags-Sta¬ 
tus wird auf Null gelöscht. 

Akkumulator Übertrag 

0 1111010 1 

11110101 0 
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Der ROL-Befehl gestattet vier Arten der Adressierung des Datenspeichers. Die¬ 
se sind: 


1) Null-Seite(direkt)-ROL addr 

2) Absolut (direkt) - ROL addr16 

3) Null-Seite indiziert mit Indexregister X - ROL addr,16 

4) Absolut indiziert mit Indexregister X- ROL addrl 6,X 

Das erste Byte des Objektcodes bestimmt, welche Adressier-Art wie folgt ge¬ 
wählt wurde: 



Wir wollen den ROL-Befehl mit indizierter Nullseiten-Adressierung (unter Ver¬ 
wendung des Indexregisters X) illustrieren. Die übrigen Adressier-Arten sind an 
anderer Stelle gezeigt. 
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Rotiere das gewählte Speicherbyte um ein Bit nach links durch den Übertrags- 
Status. Es sei angenommen cc-34,6. rr= 16i 6 , der Inhalt des Speicherplatzes 
004A, S sei 2En und der Übertrags Status ist Null. Nach Ausführung eines Be¬ 
fehls 


ROL S34.X 

wird der Speicherplatz 004A, 6 den Wert SCis enthalten 


Setzt N auf 0 


{004A i e* Übertrag 
00101110 0 
01011100 0 



Nicht-Null-Ergebms setzt Z auf 0 
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ROR - ROT ATE ACCUMULATOR OR MEMORY RIGHT, 
THROUGH CARRY 

(ROTIERE AKKUMULATOR ODER SPEICHER NACH 
RECHTS DURCH DEN ÜBERTRAG) 

Dieser Befehl rotiert den Akkumulator oder das gewählte Speicherbyte um ein 
Bit nach rechts durch den Übertrag. 

Betrachten wir zuerst die Rotation des Akkumulators. 


ROR A 



Rotiere den Inhalt des Akkumulators um ein Bit nach rechts durch den Über¬ 
trags-Status. Der Akkumulator enthalte angenommen 7A, 6| und der Übertrags- 
Status wird auf 1 gesetzt. Die Ausführung des Befehls 

ROR A 


wird diese Resultate liefern: Der Akkumulator wird BD 16 enthalten, und der Über¬ 
trags-Status wird Null sein. 


Setzt N auf 1 


Akkumulator Übertrag 


01111010 1 
10111101 0 



Nicht-Null-Ergebnis setzt Z auf 0 
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Der ROR-Befehl gestattet vier Arten der Adressierung des Datenspeichers. Die¬ 
se sind: 

1) Null-Seite (direkt) - ROR addr 

2) Absolut (direkt) - ROR addr16 

3) Null-Seite indiziert mit Indexregister X - ROR addr.X 

4) Absolut indiziert mit Indexregister X - ROR addr16,X 

Das erste Byte des Objektcodes bestimmt, welche Adressier-Art wie folgt ge¬ 
wählt wurde: 



Wir wollen den ROR-Befehl mit absoluter indizierter Adressierung illustrieren 
(unter Verwendung des Indexregisters X). Die übrigen Adressier-Arten sind an 
anderer Stelle gezeigt. 
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Es sei angenommen rr - 14, 6l ppqq <= 0100i 6 . der Inhall des Speicherplatzes 
0114( 6 sei EDi6 und der Übertrags-Status sei 1. Nach Ausführung eines Befehls 

ROR $0100,X 

wird der Übertrags Status 1 sein, und der Speicherplatz 0114, s wird F6| G enthal¬ 
ten. 


Setzt N aut 1 


(0114 16 ) Übertrag 

11101101 1 

11110110 1 
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RTI - RETURN FROM INTERRUPT 

(KEHRE VON UNTERPROGRAMM ZURÜCK) 

Holt das Statusregister (P) und den Befehlszähler von der Spitze des Stapels zu¬ 
rück. Die Register und die entsprechenden Speicherplätze, von denen sie gela¬ 
den wurden, sind folgende, wobei angenommen wird, daß der Stapelzeiger ss 
bei Beginn der Betehls Auslührung enthält 


Speicherplatz Register 

Olss+l Statusregister (P) 

01 ss+2 Niederwertiges Byte des Betehlszahlers 

01 ss+3 Hochweitiges Byte des Befehlszählers 

Der abschließende Wert des Stapelzeigers ist sein Anfangswert plus 3 Die alten 
Werte des Statusregisters und des Befehlszählers gehen verloren 
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Oer Stapelzeiger enthalte angenommen E8, 6 , der Speicherplatz 01 E9, 6 enthalte 
C1 1 6, der Speicherplatz 01 EA, 6 enthalte 3E 1S , und der Speicherplatz 01 EB, S ent¬ 
halte D5i*. Nachdem der Befehl RTI ausgeführt wurde, wird das Statusregister 
C1 1 e, der Slapelzeiger EB, 6 und der Befehlszähler D53E, 6 enthalten (dies ist die 
Adresse, von wo ab die Befehls-Ausführung fortgesetzt wird). Die Status werden 
wie folgt lauten: 



Beachten Sie, daß das Unterbrechungs-Maskenbit gesetzt oder gelöscht wird, 
abhängig von seinem Weil zu der Zeit, bei der das Statusregister gespeichert 
wurde, unter der Annahme, daß die Unlerbrechungs-Setviceroutine es nicht än¬ 
dert, während es sich auf dem Stapel befand. 
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RTS - RETURN FROM SUBROUTINE 

(KEHRE VON UNTERPROGRAMM ZURÜCK) 

Dieser Befehl holl einen neuen Befehlszähler Wert von der Spitze des Stapels 
und inkremenlierl ihn, bevor er zum Holen eines Befehls verwendet wird. Beach¬ 
ten Sie, daß der Slapelzeiger vor dem Laden jedes Dalenbytes inkrementiert 
wird und sein endgültiger Werl um 2 größer ist als sein Anfangswerl. RTS wird 
normalerweise am Ende eines Unterprogramms zum Zurückspeichern der 
Rückkehr-Adresse verwendet, die im Stapel durch einen JSR-Befehl aufbewahrt 
wurde. Erinnern Sie sich daran, daß die Rückkehr-Adresse,die durch JSR aufbe- 
wahrl wurde, in Wirklichkeit die Adresse des drillen Bytes des JSR Befehls 
selbst ist. Daher muß RTS diese Adresse inkrementieren, bevor sie zur Wieder¬ 
aufnahme des Hauptprogramms verwendet wird. Der vorausgehende Inhalt des 
Befehlszählers gehl verloren. Jedes Unterprogramm muß wenigstens einen 
RTS-Befehl enthalten. 



Durch einen RTS-Befehl werden keine Status geändert 

Der Slapelzeiger enthalte angenommen DF t6 , der Speicherplatz 01E0 16 enthalte 
08 , 6 , und der Speicherplatz 01 E1, 6 enthalte 7C, 6 Nachdem der Befehl RTS aus¬ 
geführt wurde, wird im Slapelzeiger E1, 6 und im Befehlszähler 7C09 16 liegen 
(dies ist die Adresse, von wo ab die Befehls-Ausführung fortgesetzt wird). 
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SBC-SUBTRACT MEMORY FROM ACCUMULTOR 
WITHBORROW 

(SUBTRAHIERE SPEICHER VOM AKKUMULATOR 
MIT BORGEN) 

Subtrahiert den Inhalt des gewählten Speicherbytes und das Komplement des 
Übertrags-Status (d.h. 1 - C) vom Inhalt des Akkumulators. Dieser Betehl bietet 
die gleichen Speicher-Adressiermöglichkeiten wie der AOC-Betehl Das erste 
Byte des Objektcodes wählt die Adressier-Art wie folgt 

7654321G ^ Bit-Nummer 
hhh|a|a|a|>|lK ■ Objekt-Code 


Bit-Wert 
tür aaa 

Hexadezimaler 

Objekt-Code 

Adressier-Art 

Anzahl 
der Bytes 

000 

El 

Indirekt, vor-indiziert mit X 

2 

001 

E5 

Null-Seite (direkt) 

2 

010 

E9 

Unmittelbar 

2 

011 

ED 

Absolut (direkt) 

3 

100 

Fl 

Indirekt, nach-indiziertmit Y 

2 

101 

F5 

Null-Seite indiziert mitX 

2 

110 

F9 

Absolut indiziert mit Y 

3 

111 

FD 

Absolut indiziert mit X 

3 


Wir wollen den SBC-Betehl unter Verwendung vor-indizierter indirekter Adres¬ 
sierung (über das Indexregister X) illustrieren Schlagen Sie die Besprechung 
der Adressier-Arten und anderer arithmetischer und logischer Befehle für Bei¬ 
spiele der übrigen Adressier Arten nach. 


Daten- 



Subtrahiere den Inhalt des gewählten Speicherbytes und das Komplement des 
Übertrags-Status (1 - C) vom Akkumulator, wobei alle Register-Inhalte als einfa¬ 
che Binärdaten behandelt werden. Beachten Sie jedoch, daß alle Daten dezimal 
(BCD) behandelt werden, wenn der D-Status gesetzt ist. 


Es sei angenommen xx - 14,6, cc = 15 1 6 , rr - 37,«. ppqq - 07E2, S . yy - 
(07E2,s)-34, 6 und C-0. Nach Ausführung eines Befehls 

SBC ($15,X) 

wurde der Inhalt des Akkumulators aut DF, S geändert. 


' i yj i v_r v_r 


Zweier-Komplement von 35 = 1 1 00 1 0 1 1 

, 1,1 0 11111 


(siehe Anmerkung unten) 


Setze Übertrag auf 0- 
Setze N auf 1 - 


L 


NiCht-NuN-Ergebnis setzt 
Z aut 0 


0 V 0 - 0, setzt V aulO 


Anmerkung: xx-yy (1 C) xx-(yy-tC); 

daher 14,6 - 34,6 —(1 — 0) = 14,6 - (34,6 + 1)™14,6— 35,6 


Beachten Sie, daß der resultierende Übertrag kein Borgen darsteilt. Er ist viel¬ 
mehr das Gegenteil eines Borgens, da er aut 1 gesetzt ist, wenn kein Borgen er¬ 
forderlich ist, und gelöscht, wenn ein Borgen erforderlich ist. Sie sollten sehr 
sorgfältig diese Verwendung beachten, da sie sich von den meisten anderen Mi¬ 
kroprozessoren unterscheidet, die den Übertrag komplementieren, bevor er 
nach einer Subtraktion gespeichert wird. 


SBC ist der einzige binäre Subtraktions-Betehl. Um ihn in Einzelbyte-Operati¬ 
onen zu verwenden oder um die niederwertigen Bytes zweier Multibyte Zahlen 
zu subtrahieren, muß ein vorhergehender Befehl (SEC) ausdrücklich C auf 1 set¬ 
zen, so daß dieser die Operation nicht beeinflußt. Erinnern Sie sich daran, daß C 
vor einer Subtraktion gesetzt (nicht gelöscht) werden muß, da seine Bedeutung 
entgegengesetzt dem gewöhnlichen Borgen ist. Beachten Sie auch, daß der Mi¬ 
kroprozessor 6502 - anders als die meisten anderen - keinen Subtraktions- 
Betehl besitzt, der den Übertrag nicht enthält. 
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SEC-SET CARRY 

(SETZE ÜBERTRAG) 

SEC 

38 

Setzt den Übertrags-Status auf 1. Es werden keine anderen Status oder Regi¬ 
ster-Inhalte beeintlußt. Beachten Sie, daß dieser Belehl als Teil einer normalen 
Subtraktions-Operation benötigt wird, da der einzige beim Mikroprozessor 6502 
vedugbare Subtraktions-Befehl der SBC ist, der auch den komplementierten 
Übertrags-Status subtrahiert. Dieser Belehl ist auch beim Beginn einer Multi- 
byte-Subtraktion erforderlich, da es niemals ein Borgen vom niedrigstwertigen 
Byte gibt. 


Daten- 
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SED - SET DECIMAL MODE 

(SETZE DEZIMAL-BETRIEBSART) 

SED 

re 


Setzt den Dezimai-Betriebsart Status aut 1. Es wird kein anderer Status oder Re¬ 
gister-Inhalt beeintlußt. Dieser Belehl wird dazu verwendet, um den Prozessor 
6502 in die Dezimal-Betriebsart zu versetzen, in der ADC- und SBC-Belehle 
BCD-Ergebnisse anstatt binärer Resultate liefern. Der Programmierer sollte sehr 
sorglältig auf die Tatsache achten, daß das gleiche Programm unterschiedliche 
Resultate erzeugen wird, abhängig vom Zustand des Dezimai-Betriebsarts- 
Status. Dies kann zu unangenehmen und überraschenden Fehlern führen, wenn 
der Zustand des Dezimal-Betriebsarts-Status nicht sorglältig beobachtet wird. 


Daten- 
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SEI - SET INTERRUPT MASK (DISABLE INTERRUPT) 

(SETZE UNTERBRECHUNGS-MASKE - SPERRE 
UNTERBRECHUNG) 

76 

Setzt die Unterbrechungs-Maske im Statusregister. Dieser Befehl sperrt die Un- 
lerbrechungs-Servicemöglichkeil des 6502, das heißt, der 6502 wird auf die Un- 
lerbrechungs-Anforderungs Sleuerleilung nicht reagieren. Es werden keine an¬ 
deren Register oder Status beeinflußt. Die Unterbrechungs-Maske ist Bit 2 des 
Statusregisters (P). 


n v e o i 2 c 

-I 1 1-Ll'XD 



Daten- 



STA-STORE ACCUMULATOR IN MEMORY 

(SPEICHERE AKKUMULATOR IN SPEICHER) 

Speichert den Inhalt des Akkumulators in den spezifizierten Speicherplatz. 
Diese Befehl bietet die gleichen Speicher-Adressiermöglichkeilen wie der ADC- 
Befehl mit der Ausnahme, daß eine unmittelbare Adressier-Möglichkeil nicht 
vorhanden ist. Das erst Byte des Objeklcodes wählt die Adressier-Art wie folgt: 

7 6 5 4 3 2 1 0 ^-Bit-Nummer 

|l lQ|t|a|a|aioll | ^ ODIBKl.Codfl 


Bit-Werl 
für aaa 

Hexadezimaler 

Objekt-Code 

Adressier-Art 

Anzahl 

der Bytes 

000 

81 

Indirekt, vor-indizierl mit X 

2 

001 

85 

Null-Seite (direkt) 

2 

010 

89 

Nicht verwendet 


011 

8D 

Absolut (direkt) 

3 

100 

91 

Indirekt, nach-indizierl mit Y 

2 

101 

95 

Null-Seile indiziert mit X 

2 

110 

99 

Absolut indiziert mit Y 

3 

111 

9D 

Absolut indiziert mit X 

3 


Wir wollen den STA-Befehl mit direkter Nullseiten-Adressierung illustrieren. 
Schlagen Sie die Besprechung der Adressier-Arten und anderer arithmetischer 
und logischer Befehle für Beispiele der übrigen Adressier Arten nach. Es wer¬ 
den keine Status beeinflußt. 


Da*cn- 



OOqq 


Tun mm 
mm n tm ♦ 1 
mmmm♦2 


Speichere den Inhalt des Akkumulators in den Speicher. Es sei angenommen 
xx= 63i«und qq - 3A,*. Nachdem der Befehl 

STA $3A 

ausgeführl wurde, wird der Inhalt des Speicherplatzes 003 Ai 6 gleich 63 16 sein. 
Es werden keine Register oder Status beeinflußt. 
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STX - STORE INDEX REGISTER X IN MEMORY 

(SPEICHERE INDEXREGISTER X IN SPEICHER) 

Speichert den Inhalt des Indexregisters X in den gewählten Speicherplatz. Die 
zulässigen Adressier-Arlen sind: 

1) Null-Seile (direkt) - STX addr 

2) Absolut (direkt) - STX addr16 

3) Null-Seile indiziert mit Y - STX addr.Y 

Beachten Sie, daß es hier keine indizierten Adressier-Arten unter Verwendung 
des Indexregisters X gibt. Es gibt auch keine absolute indizierte Adressierung 
STX und LDX sind die einzigen Befehle, die die indizierte Nullseiten-Adressie- 
rung mit Indexregister Y verwenden. Es werden keine Status beeinflußt. 

Das erste Byte des Objektcodes wählt die Adressier-Art wie folgt: 

7 6 5 4 3 2 1 0 -Sit-NurnrKr 

TöTHTbT-' ) 1 Je]-«-Obiekt-Code 


Bit-Wert 
für aaa 

Hexadezimaler 

Objekt-Code 

Adressier-Art 

Anzahl 
der Bytes 

00 

86 

Null-Seile (direkt) 

2 

01 

8E 

Absolut (direkt) 

3 

10 

96 

Null-Seile indiziert mit Y 

2 

11 

9E 

Nicht verwendet 



Wir wollen den STX-Befehl unter Verwendung der indizierten Nullseiten- 
Adressierung mit Indexregister Y zeigen. Schlagen Sie die Besprechung der 
Adressier-Arten und anderer arithmetischer und logischer Befehle für Beispiele 
der übrigen Adressier-Arten nach. 


Oaten- 


SP 

PC 



Speichere den Inhalt des Indexregisters X in das gewählte Speicherbyte. Es sei 
angenommen cc~28 I6 , rr- 20, s und yy= E9, 6 . Nach Ausführung des Befehls 

STX $28.Y 

wird der Speicherplatz 0048, 8 den Wer: E9, 8 enthalten. Es werden keine Regi¬ 
ster oder Status beeinflußt. 
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sty - store Index Register y in Memory 

(SPEICHERE INDEXREGISTER Y IN DEN SPEICHER) 

Speichert den Inhalt des Indexregisters V in den gewählten Speicherplatz. Die 
zulässigen Adressier-Arten sind: 

1) Null-Seite (direkt) - STV addr 

2) Absolut (direkt) - STY addr 16 

3) Null-Seite indiziert mit X - STY addr.X 

Beachten Sie, daß keine indizierten Adressier-Arten unter Verwendung des In¬ 
dexregisters Y gibt. Es gibt auch keine absolute indizieite Adressier-Art Es wer¬ 
den keine Status oder Register beeinflußt. 

Das erste Byte des Objektcodes wählt die Adressier-Art wie folgt: 

7 6 5 4 3 2 1 0 ^ a » -i-- 

|i 1 o I o I b ) b [ I |o|o [ » Obiekt-Code 


Bit Wert 
für aaa 

Hexadezimaler 
Objekt Code 

Adressier-Art 

Anzahl 
der Bytes 

00 

84 

Null-Seite (direkt) 

2 

01 

ec 

Absolut (direkt) 

3 

10 

94 

Null-Seite indiziert mit X 

2 

11 

9C 

Nicht verwendet 



Wir wollen den STY-Befehl mit absoluter direkter Adressierung illustrieren. 
Schlagen Sie die Besprechung der Adressier-Arten und anderer arithmetischer 
und logischer Befehle für Beispiele der übrigen Adressier-Aiten nach. 


Daten- 



TAX - MOVE FROM ACCUMULATOR TO INDEX REGISTER X 
(TRANSFERIERE VOM AKKUMULATOR ZUM 
INDEXREGISTER X) 

TAX 

AA 


Bringt den Inhalt des Akkumulators zum Indexregister X. Setzt den Negativ- und 
Null-Status entsprechend. 


kl v e o i z c 

P R I 1 I hl I 




ÖMfarv 



Es sei angenommen xx -00i». Nach Ausführung des TAX-Befehls wird sowohl 
der Akkumulator wie das Indexregister X den Wert 00i 6 enthalten. 


Setze N auf 0 


00000000 



Nicht-Nuii-Ergebnis setzt 

Z auf 1 


Die folgende Befehls-Sequenz wird den Inhalt des Indexregisters vom Stapel 
nach Abschluß eines Unterprogrammes oder einer Unterbrechungs-Service- 
Routine zurückspeichern: 

PLA ;HOLE ALTES X-REGISTER VOM STAPEL 
TAX SPEICHERE ZUM X REGISTER ZURÜCK 


Speichere den Inhalt des Indexregisters Y in das gewählte Speicherbyte. Es sei 
angenommen yy = 01 1 6 und ppqq-08F3, s . Nachdem der Befehl 

STY S08F3 

ausgeführt wurde, wird der Speicherplatz 08F3| 6 den Wert 01 16 enthalten. Es 
werden keine Register oder Status beeinllußt. 
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TAY - MOVE FROM ACCUMULATOR TO INDEX REGISTER Y 
(TRANSFERIERE VOM AKKUMULATOR ZUM 
INDEXREGISTER Y) 

TAY 

A8 


Bringt den Inhalt des Akkumulators zum Indexregister Y. Setzt den Negativ- 
und Nullstatus entsprechend. 


Daten- 



Es sei angenommen xx = F1 1S . Nach Ausführung des TAY-Befehls wer¬ 
den sowohl der Akkumulator wie das Indexregister Y den Wert F1 )6 ent¬ 
halten. 


Setze N auf 1 


11110001 

-J L 


Nicht-Null-Ergebnis setzt 
Zauf 0 


Die folgende Befehls-Sequenz wird den Inhalt des Indexregisters Y vom Stapel 
nach Abschluß eines Unterprogrammes oder einer Unterbrechungs-Sevice- 
Routine zurückspeichern: 

PLA IHOLE ALTES Y-REGISTER VOM STAPEL 
TAY ;SPEICHERE ES ZUM Y-REGISTER ZURÜCK 
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TSX - MOVE FROM STACK POINTER TO INDEX REGISTER X 
(TRANSFERIERE VOM STAPELZEIGER ZUM 
INDEXREGISTER X) 

TSX 

BA 

Bringt den Inhalt des Stapelzeigers zum Indexregister X. Setzt den Negativ- und 
Nullstatus entsprechend. Beachten Die, daß TSX der einzige Befehl des 6502 
ist, der Ihnen den Zugriff zum Stapelzeiger gestattet. Eine typische Befehls- 
Sequenz, die den Wert des Stapelzeigers im Speicherplatz TEMP aufbewahrt ist. 

TSX ;BRINGE STAPELZEIGER ZU X 

STX TEMP ;BEWAHRE STAPELZEIGER IM SPEICHER AUF 


Daten- 




Wenn beispielsweise der Stapelzeiger ED 1S nach Ausführung des TSX- 
Befehls den Wert EDi 6 enthält, werden sowohl der Stapelzeiger wie das 
Indexregister X den Weil EDi 6 enthalten. 


Setze N auf 1 


11101101 

L 


Nicht-Null-Ergebnis setzt 
Z auf 0 
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TXA - MOVE FROM INDEX REGISTER X TO ACCUMULATOR 
(TRANSFERIERE VOM INDEXREGISTER X ZUM 
AKKUMULATOR) 


TXA 

BA 

Bringt den Inhalt des Indexregisters X zum Akkumulator und setzt den Negativ- 
und Nullstatus entsprechend. Die folgende Befehls-Sequenz wird den Inhalt des 
Indexregisters X im Stapel vor der Ausführung eines Unterprogrammes oderei¬ 
ner Unterbrechungs-Service-Routine aufbewahren: 

TXA ;BRINGE X-REGISTER ZUM AKKUMULATOR 
PHA ;BEWAHRE X-REGISTER IM STAPEL AUF 


TXS- MOVE FROM INDEX REGISTER X TO STACK POINTER 
(TRANSFERIERE VOM INDEXREGISTER X ZUM 
STAPELZEIGER) 

TXS 

9A 

Bringt den Inhalt des Indexregisters X zum Stapelzeiger. Es werden keine an¬ 
deren Register oder Status beeinflußt. Beachten Sie, daß TXS der einzige Befehl 
des 6502 ist, der Ihnen die Bestimmung des Wertes im Stapelzeiger gestattet. 
Eine typische Befehls Sequenz, die den Stapelzeiger mit dem Wert LAST lädt 
lautet: 

LDX #LAST ;HOLE LAGE DES STAPELS AUF SEITE 1 

TXS PLAZIERE START-PLATZ IN STAPELZEIGER 


N V B D I Z C 

- ED I ITT I 




Daten¬ 


speicher 


mmmm 
mmmm♦ ) 


Programm- 
| Speicher 


8A 


Es sei angenommen rr - 38 18 - Nach Ausführung des TXA-Befehls werden so- 
wohl das Indexregister X wie der Akkumulator den Wert 38,s enthalten. 


Setze N auf 1 


00111011 

_J L 


Nicht-Null-Ergebnis setzt 
Z auf 0 


Beachten Sie, daß TXS keinen Status beeinflußt, im Gegensatz zu TSX, der so¬ 
wohl den Null- wie den Negativ-Status beeinflußt. 


n v b p i z c 

• m um 


D 



Daten- 



Es sei angenommen rr - F2,*. Nach Ausführung des TXS-Befehls enthalten so¬ 
wohl das Indexregister wie der Stapelzeiger den Wert F2 i 8 , wodurch 01 F2i s zum 
momentanen Ort des Stapels wird. Es werden keine Status oder andere Register 
beeinflußt. 
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TYA - MOVE FROM INDEX REGISTER Y TO ACCUMULATOR 
(TRANSFERIERE VOM INDEXREGISTER Y ZUM 
AKKUMULATOR) TYA 

98 


Bringt den Inhalt des Indexregisters Y zum Akkumulator und setzt den Negativ- 
und Nullstatus entsprechend. Die tolgende Befehls-Sequenz wird den Inhalt des 
Indexregisters Y in den Stapel vor Ausführung eines Unterprogrammes oder 
einer Unterbrechungs-Service-Routine aulbewahren: 

TYA jBRINGEY-REGlSTER ZUM AKKUMULATOR 
PHA ;BEWAHRE Y-REGISTER IM STAPEL AUF 


N V B D I Z C 

I I 1~ED 






Es sei angenommen rr = AF 1S . Nach Ausluhrung des TYA-Betehls werden so¬ 
wohl das Indexregister Y wie der Akkumulator den Wert AF 16 enthalten. 


Setze N auf 1 


10 10 111 1 

_J L_ 


Nicht-Null-Ergebnis setzt 
Zauf 0 


KOMPATIBILITÄT 6800/6502 


Obwohl der Mikroprozessor 6502 an und für sich allein 
verwendet werden kann, Ist eine seiner wesentlichen Ei¬ 
genschaften seine Ähnlichkeit mit dem weit verbreiteten 
Mikroprozessor 6800. Diese Ähnlichkeit reicht Jedoch nicht aus, um für diesen 
Prozessoren geschriebene Programme auf der Maschinen- oder Assembler- 
Ebene des anderen laufen zu lassen, reicht jedoch aus, daß Program¬ 
mierer leicht von einer CPU zur anderen wechseln können. Die meisten der ex¬ 
ternen Hilfsbausteine, die für einen dieser Prozessoren entwickelt wurden, kön¬ 
nen auch mit dem anderen verwendet werden. Die Kapitel 9 und 1 0 von "An 
Introduction to Microcomputers: Volume 2 - Some Real Microprocessors” be¬ 
sprechen diese Hardware-Kompatibilität im Detail. 

Wir wollen die Mikroprozessoren 6800 und 6502 kurz beschreiben und sie in 
Hinblick aul ihre Register, Status, Adressier-Arten und Belehlssätze vergleichen. 
Sie sollten beachten, daß keiner der beiden Prozessoren das Spiegel¬ 
bild des anderen darstellt, sie besitzen jedoch weit mehr Ähnlichkeiten als ge¬ 
genüber einem 8080, Z80. F8 oder 2650 Diese Beschreibung sollte Ihnen eine 
gewisse Vorstellung geben, welchen Problemen Sie gegenüberstehen, wenn Sie 
voneinerCPU zu einer anderen übetwechseln wollen, 


Was die Register betrifft, besitzen sowohl der 6800 wie 
der 6502 einen primären Akkumulator (A-Register) mit 
8-Bit und einen 16-Bit-Befehlszähler (oder PC-Register). 

Die übn'gen Register jedoch sind etwas unterschiedlich. Der 6800 besitzt einen 
zweiten 8-Bit-Akkumulator (B-Register), ein 16-Bit-lndexregister und einen 
16-Bit-Stapelzeiger. Der 6502 andererseits besitzt zwei 8-Bit-lndexregister und 
einen 8-Bit-Stapelzeiger. Daher können die Indexregister des 6502 nicht eine 
vollständige 16-Bit-Speicher-Adresse aulbewahren, während das Indexregister 
des 6800 dies kann. Ferner kann der RAM-Stapel des 6800 infolge seines 
16-Bit-Stapelzeigers überall im Stapel liegen, während dei 
6502 immer auf Seite 1 liegt. 

Für die Status gilt, daß der 6800 und der 6502 identische 
Null-, Überlauf-, Negativ- und Unterbrechungsmasken- 
Status besitzen. Der Unterschied beim Übeitrags-Status 
liegt darin, daß die Version dieses Flags beim 6800 und 
6502 entgegengesetzte Bedeutung nach Subtraktions-Operationen haben, Der 
Übertrag des 6800 wird auf 1 gesetzt, wenn ein Borgen erforderlich ist und an¬ 
dernfalls auf 0. Der Übertrag des 6502 wird auf 0 gesetzt, wenn ein Borgen er¬ 
forderlich ist, und andernfalls auf 1. Dieser Unterschied bedeutet, daß vor einer 
Multibyte-Subtraktions : Operationen der Programmierer den Übertrag beim 6800 
löschen und den Übertrag beim 6502 setzen muß. Der 6800 und 
6502 unterscheiden sich auch darin, wie sie Dezimal-Arithmetik ausführen. 
Der 6800 besitzt ein Halb-Übertrags-Flag (oder Übertrag von Bit 3). während der 
6502 ein Flag für die Dezimal-Betriebsart besitzt. Ferner hat der 6502 ein 
Break-Flag, das es beim 6800 nicht gibt. Es ist beim 6800 nicht erforderlich, da 
der Software-Unterbrechungsbefehl des 6800 automatisch vektorisiert wird, un¬ 
abhängig von der normalen Unterbrechungs-Reaktion. 


RAM-Stapel des 


6800/6502- 

STATUS- 

VERGLEICH 


6800/6502- 

REGISTER- 

VERGLEICH 


6800/6502- 

ÄHNLICHKEIT 
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Der Mikroprozessor 6502 besitzt wesentlich mehr Adres- 
sier-Arten als der 6800. Dies ist besonders deshalb erfor¬ 
derlich. da die Indexregister des 6502 nur 8-Bits lang sind. 

Tabelle 3-7 vergleicht die bei den beiden Prozessoren ver¬ 
fügbaren Adressier-Arten. Der Mikroprozessor 6800 besitzt keine indirekte 
Adressier-Art, keine Kombinationen von Indizierung und indirektem Vorgehen 
und keine absoluten indizierten Adressier-Arten. Es gibt auch einige 
andere Unterschiede bei den Ausdrücken, welche Betriebsarten mit be¬ 
stimmten Befehlen verfügbar sind. Wir wollen diese Unterschiede nicht bespre¬ 
chen, sie sind jedoch in Tabelle 3-6 aufgezählt. 


Tabelle 3-7. Bei den Mikroprozessoren 6800 und 6502 verfügbare 
Speicheradressierarten. 


6800 

6502 

Unmittelbar 

Unmittelbar 

Direkt (Null-Seite) 

Null-Seite (direkt) 

Erweitert (absolut direkt) 

Absolut (direkt) 

Indiziert (absolut) 

Absolut indiziert 

Null-Seite indiziert 

Nach-indiziert indirekt 
Vor-indiziert indirekt 

Indirekt 

Relativ (nur Verzweigungen) 

Relativ (nur Verzweigungen) 

Beachten Sie, daß zahlreiche unterschiedliche Varianten der indizierten 

Adressierung beim Mikroprozessor 6502 verfügbar sind, aber erinnern Sie 

sich daran, daß die Index-Register des 6502 nur 8 Bit lang sind, während 

das Indexregister des 6800 eine Länge von 1 6 Bit besitzt. 


6800/6502- 
ADR ESSIER-AHT 
VERGLEICH 


6800/6502 
VERGLEICH 
DER BEFEHLE 


Die Befehlssätze des 6800 und 6502 sind ähnlich, jedoch 
nicht identisch (siehe Tabelle 3-6). Tabelle 3-8 vergleicht 
diese beiden Sätze, wobei zuerst die Befehle aufgelistet 
sind, die.in beiden vorliegen, dann die Befehle des 6800, 
die kein Äquivalent beim 6502 besitzen, und schließen die Befehle des 6502, die 
kein Äquivalent beim 6800 besitzen. Offensichtlich resultieren diese Unterschie¬ 
de aus der Verschiedenheit der Status und Register. Zahlreiche dieser Unter¬ 
schiede sind geringfügig, und schließen Befehle ein. die ein kleiner Teil der all¬ 
gemeinen Anwendungsprogramme sind. Ein offensichtlicher Unterschied be¬ 
steht darin, daß der 6800 Additions- und Subtraktions-Befehle besitzt, die den 
Übertrags-Status (ADD und SUB) nicht beinhalten, während dies beim 6502 
nicht der Fall ist. Dies bedeutet, daß der Assemblersprachen-Programmierer 
beim 6502 ausdrücklich den Übertrags-Status löschen oder setzen muß. wenn 
dessen Wert eine Addition-oder Subtraktions-Operation nicht beeinflussen soll. 
Beachten Sie, da3 diese Ähnlichkeit der Befehlssätze nicht mehr für die Objekt¬ 
code Ebene gilt. Die tatsächlichen Maschinencodes sind bei den beiden Mikro¬ 
prozessoren völlig verschieden. 


Tabelle 3-8. Vergleich der Assemblersprache-Befehlssätze des 6800 und 

6502. 


1. 

Gemeinsame Befehle 

Befehl 

Bedeutung 

ADC 

Add with Carry (Addiere mit Übertrag) 

AMD 

Logical AND (UNDlere logisch) 

ASL 

Arithmetic Shift Left (Schiebe arithmetisch nach links) 

BCC 

Branch if Cauy Ctear (Verzweige, wenn Übertrag gelöscht) 

BCS 

Branch il Cauy Set (Verz eige, wenn Übertrag gesetzt) 

BEO 

Branch il Equal to Zero (Z= 1) (Verzweige, wenn gleich Null (Z« 1)) 

BIT 

Bit Test (Teste Bit) 

BMI 

Branch il Minus (N = 1) (Verz eige. wenn minus (Na 1» 

BNE 

Branch rf Not Equal to Zeio (Z = 0) (Verzweige, wenn nicht gleich Null 

(Z^O)) 

BPL 

Branch If Plus (N= 0) (Verzweige, wenn plus (N = 0)) 

BVC 

Branch il Oveiflow Clear (Verzweige, wenn Überlauf gelöscht) 

BVS 

Branch if Oveiflow Set (Verzweige, wenn Überlauf gesetzt) 

CLC 

Clear Cauy (Lösche Übertrag) 

CU 

Clear Interrupt Ma$k (Enable Interrupt) (Lösche Unterbrechungs-Maske 

(Gib Unterbrechung frei)) 

CLV 

Clear Overflow (Lösche Oberlauf) 

CMP 

Compare Accumulator with Memoiy (Vergleiche Akkumulator mit Spei 
eher) 

CPX 1 

Compare Index Register with Memory (Vergleiche Index-Register mit 

(auch CPY beim 6502) 

Speicher) 

DEC 

DEX» 

Decrement (by 1 ) (Dekrementiere um 1 ) 

(euch DEY beim 6502) 

Decrement Index Regisler (by 1) (Dekrementiere Index-Register um 1 ) 

EOR 

Logical Exclusive-OR (Exklusiv-ODERiere loßisch) 

INC 

INX» 

Increment (by 1 ) (Inkrementiere um 1 ) 

(auch INY beim 6502) 

Increment Index Register (by 1 ) (Inkrementiere Index-Register um 1) 

JMP 

Jump to New Location (Springe zu neuem Speicherplatz) 

JSR 

Jump to Subroutine (Springe zu Unterprogramm) 

LOA 

LOX* 

Load Accumu lator (Lade Akkumulator) 

(auch LDY beim 6502) 

Load Index Register (Lade Index-Register) 

LSR 

Logical Shift Right (Verschiebe logisch nach links) 

NOP 

No Operation (Keine Operatio n) 

ORA 

Logical (Inclusive) OR (ODERiere logisch) 

PHA (PSH beim 68003 

Push ccumulator onto Stack (Bringe Akkumulator zu Stapel) 

PLA (PUL beim 6800) 

Pull Accumulator from Stack (Hole Akkumulator vom St apel) 

ROL 

Rotate Lefr through Carry (Robere nach links durch Übertrag) 

ROR 

Rotate FVght through Carry (Rotiem nach rechts durch Übertrag) 

RTl 

Return bc*m Interrupt (Kehre von ItotedHBChu ng au rü ck) 

RTS 

Re tum bom Subroutine (Kehre von Unterprogramm zurück) 

sec- 

Subtract with Cairy (Subtrah iee mit Übertrag) 

SEC 

Set Carry (Setze Übertrag) 

SEI 

Set Inteirupt Mask (Setze Unterbmchungs-Mes ke) 

STA 

STX* 

Store Accumulator (SpeichereAkkumulator) 

(aucn STY beim 6502) 

Store Index Register (Speichere Index-Register) 

TSX 

Transfer Stack Pointer to Index Register (X) 

(Transferiere Stapelzeiger zu Index-Register (X)) 

TXS 

Transfer Index Register (X) to Stack Pointer 

(Transferiere Index-Register (X) zu Stapelzeiger 


'Das Index-Register X ist beim 6800 16 Bits lang, beim 6502 8 Bits lang, der 
auch ein Index-Register Y besitzt. 


»Beachten Sie, daß SBC beim 6502 eine andere Bedeutung als beim 6600 hat, da bei Subtraktions- 
Operationen der Übertrag des 6800 das Gegenteil des Überrags des 6502 ist. 


3-116 


3-117 












Tabelle 3-8. Vergleich der Assemblersprache-Befehlssatze des 6800 und 
6502 (Fortsetzung) 


II. 

Befehle nur für 6800 

Befehl 

Bedeutung 

ABA 

Add Accumulators (Addiere Akkumulatoren) 

ADD 

Add (wlthout Carry) (Addiere (ohne Überlragl) 

ASR 

Arlthmetic Shlft Right (Verschiebe arithmetisch nach links) 

BGE 

Branch If Greater than or Equalto Zero (Verzweige, wenn größer oder 

gleich Null) 

BGT 

Branch if Greater than Zero (Verzweige, wenn größer als Null) 

BMI 

Braneh if Higher (Verzweige, wenn höher} 

BLE 

Branch If Less than or Equal to Zero (Verzweige, wenn kleiner oder 

gleich Null) 

BLS 

Branch if Lower or Same (Verzweige, wenn kleiner oder gleich) 

BLT 

Branch if Less than Zero (Verzweige, wenn kleiner als Null) 

BRA 

Branch Uncondltionally (Verzweige unbedingt) 

BSR 

Branch to Subroutine (Verzweige zu Unterprogramm) 

CBA 

Compare Accumutators (Vergleiche Akkumulatoren) 

CLR 

Clear (Lösche) 

COM 

Logical Complement (Komplementiere logisch) 

DAA 

Decimal Adjust Accumulator (Ordne Akkumulator d ztmalan) 

DES 

Decrement Stack Pointer (by 1) (Oekrementiere Stapelzeiger um 1) 

INS 

Increment Stack Pointer (by 1} (Inkrementiere Stapelzeiger um 1) 

LOS 

Load Stack Pointer (Lade Stapofzeiger) 

NEG 

Negate (Twos Complement) (Weitere (Zweier-Komplement)) 

SBA 

Subtr ct Accumulators (Subtrahiere Akkumulatoren) 

SEV 

Set Overflow (Set 2 e Überlauf) 

STS 

Store Stack Pointer (Speichere Stapel 2 eiger) 

SUB 

Subtract (wlthout Carry) (Subtrahiere (ohne Übertrag)) 

SWI 

Software tnterrupt (llke 6502 BRK) (Software-Unterbrechung (wie 

65D2-Break)) 

TAB 

Move Irom Accumulator A to Aocuntu lator B (Bringe von Akkumulator A 

2 u Akkumulator B) 

TAP 

Move Irom Accumulator A Io CCR (Bringe von Akkumulator A zu CCR) 

T0A 

Move Irom Accumulator B to Accumufator A (Bringe von Akkumulator B 

2 u Akkumulator A) 

TPA 

Move CCR to Accumulator A (Bringe CCR zu Akkumulator A) 

TST 

Test Zero or Minus (Teste auf Null oder minus) 

WAI 

Weit for Interrupt (Warte auf Unterbrechung) 


III. 

Befehle nur für 6502 

Befehl 

Bedeutung 

BRK 

Break llike 6600 SWI) (Break (wie 6600 SWI)) 

CLD 

ClearDeoimal Mode (Lösche Dezlmal-Betriebsart) 

PHP 

Push Status Register onto Stack (Bringe Status-Register zum 

Stapel) 

PLP 

Pull Status Register from Stack (Hole Status-R gister vom Stapel) 

SED 

Set Oeclmal Mode (SetzeDezlmal-Betriebsart) 

TAX (TAY) 

Transfer Accumulator to Index Register X (V) 

(Transferi ere Akkumulator zu Index-Register X (Y)) 

TXA (TYA) 

Transfer Index Register X (Y) to Accumulator 

(Transferiere Index-Register X (Y) zu Akkumulator) 


ASSEMBLER-VEREINBARUNGEN FÜR DEN 
MOS-TECHNOLOGY 6502 


Der Standard-Assembler ist von den Herstellern des 6502 erhältlich sowie auf 
den wicht igsten Time-Sharing-Netzwerken verfügbar. Er ist auch in den mei¬ 
sten Entwicklungs-Systemen enthalten. Cross-Assmbler-Versionen sind für die 
meisten großen Computer und für zahlreiche Minicomputer erhältlich. 

FELD-AUFBAU DES ASSEMBLERS 

Die Befehle in Assemblersprache haben den Standard-Feldaufbau (siehe Ta¬ 
belle 2-1). Die eiforderlichen Begrenzungzeichen sind: 

1) Ein Zwischenraum nach einer Marke. Beachten Sie, daß alle Marken in 
Spalte 1 beginnen müssen. 

2) Ein Zwischneraum nachdem Operationscode. 

3) Ein Komma zwischne Operanden im Adressen-Feld, d.h., zwischen der Ver¬ 
setzungs-Adresse und X oder Y zur Anzeige der Indizierung mit Indexregi¬ 
ster X oder Y. 

4) Klammem um Adressen, die indirekt zu verwenden sind. 

5) Ein Strichpunkt oder Rufzeichen (wir wollen den Strichpunkt verwenden) 
vor einem Kommentar. 

Typische Assemblersprachen-Befehle des 6502 sind: 


START LDA (1000,X) ;HOLE LÄNGE 

ADC NEXT 

LAST BRK ;EN dE DES ABSCHNITTES 

MARKIERUNGEN (LABELS) 

Der Assembler gestattet oft nur sechs Zeichen in Markierungen und unter¬ 
drückt weitere. Das erste Zeichen muß ein Buchstabe sein, während darauf¬ 
folgende Zeichen Buchstaben oder Ziffern sein müssen. Die Einzelzeichen A, X 
und Y sind für den Akkumulator und die beiden Indexregister reserviert. Die 
Verwendung von Operationscodes als Markierungen ist häufig nicht gestattet 
und stellt auch keine gute Programmier-Technik dar. 
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PSEUDO-OPERATIONEN 

Der Assembler besitzt die folgenden bestimmten Pseudo-Operationen: 


.BYTE - Form Byte-Lenght Data 

.DBYTE - Form Double-Byte-Lenght Data with MSBs First 

.END - End of Program 

.TEXT - Form String of ASCII Charakters 

.WORD - Form Double-Byte-Lenght Data with LSBs First 

= - Equata 

Andere Pseudo-Operationen können ausgeführt werden, indem der Stellen¬ 
zähler des Assemblers (gekennzeichnet mit *) auf einen neuen Wert gebracht 

wird. Beispiele sind: 

* = ADDR - Setze Programm-Anfang auf ADDR 
*= *-rN - Reserviere N Bytes für Datenspeicher 


.BYTE, .DBYTE, .TEXT und WORD sind die 
Daten-Pseudo-Operationen, die zum Plazieren 
von Daten in ein ROM verwendet werdea 
BYTE wird für 8-Bit-Daten verwendet, .TEXT 
für 7-Bit-ASCII-Zeichen (MSB ist null), .DBYTE für 16-Bit-Daten mit den höchst¬ 
wertigen Bits zuerst und WORD für 16-Bit Adressen oder Daten mit dem 
niedrigstwertigen Bit zuerst. Beachten Sie speziell den Unterschied zwischen 
DBYTE und WORD 

Beispiele: 

ADDR .WORD $3165 

ergibt (ADDR) = 65und(ADDR+1) -31 (hex). 

TCONV BYTE 32 

Diese Pseudo-Operation plaziert die Zahl 32 (20, 8 ) in das nächste Byte des 
ROMs und weist den Namen TCONVder Adresse dieses Bytes zu. 

ERROR .TEXT /ERROR/ 

Diese Pseudo-Operation plaziert die 7-Bit-ASCII-Zeichen E, R, R, O und R in die 
nächsten fünf Bytes des ROMs und weist den Namen ERROR der Adresse des 
ersten Bytes zu. Jedes Einzelzeichen (nicht nur /) kann zum Einrahmen des 
ASCII-Textes verwendet werden, aber wir wollen immer den / in Hinkunft ver¬ 
wenden. 

MASK DBYTE $1000 

ergibt (MASK) - 10 und (MASK +1) - 00. 

OPERS .WORD FADD, FSUB, FMUL, 

FDIV 

Diese Pseudo-Operation plaziert die Adressen FADD, FSUB, FMUL und FDIV in 
die nächsten acht Speicherbytes (niedrigstwertige Bytes zuerst) und weist den 
Namen OPERS der Adresse des ersten Bytes zu 


Die Operation *=* +N ist die Reserve Pseudo- 
Operation, die zum Zuweisen von Speicher¬ 
plätzen im RAM verwendet wird. 

Sie weist eine gegebene Anzahl von Bytes zu. *«* ist die Equate- oder die 
Define-Pseudo-Operation. die zur Definition von Namen verwendet wird 
*=ADDR ist die Standard-Origin-Pseudo Operation. 

Programme für den 6502 besitzen gewöhnlich mehrere Origins. die wie folgt 
verwendet werden: 

1) Zum Spezifieren der Reset- und Unterbrechungs-Service-Adresse. Diese 
Adressen müssen in die höchstwertigen Speicher-Adressen in dem System 
plazier: werden (gewöhnlich FFFA iS bis FFFF| 6 ). 

2) Zum Spezifizieren der Start-Adressen der momentanen Reset- und Unterbre- 
chungs-Service-Routinen. Diese Routinen selbst können irgendwo im Spei¬ 
cher plaziert werden. 

3) Zum Spezifizieren der Stari-Adresse des Hauptprogramms 

4) Zum Spezifizierender Start-Adressen von Unterprogrammen. 

5) Zur Definition von RAM-Speicherbereichen. 

6) Zur Definition eines Bereiches (immer auf Seite 1) für den RAM-Stapel. 

7) Zum Spezifizieren von Adressen, die für E/A-Ports und spezielle Funktionen 
dienen. 

Beispiele: 

RESET =$3800 

*=$FFFC 

WORD RESET 

*=RESET 

Anmerkung: $ bedeutet "hexadezimal" 

Diese Sequenz plaziert die Reset-Befehls-Sequenz in den Speicher, beginnend 
bei Adresse 3800,« und plaziert diese Adresse in die Speicherplätze (Adressen 
FFFC,« und FFFD,«), von wo die CPU des 6502 die Reset-Adressen holt. 

Die hierauf folgende Befehls-Sequenz wird im Speicher aufbewahrt, beginnend 
beim Speicherplatz C000,«. 

MAIN -$C000 

'-MAIN 

END markiert einfach das Ende des Assemblersprachen-Programmes. 


.BYTE, .DBYTE, 

.TEXT, .WORD 
PSEUDO-OPERATION E N 


SET ORIGIN- 
PSEUDO-OPERATION 
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MARKIERUNGEN BEI PSEUDO-OPERATIONEN 

Oie Regeln und Empfehlungen für Markierungen bei Pseudo-Operationen des 
6502 sind folgende: 

1) Einfache Equales, so wie etwa MAIN-SCOOO, erfordern Markierungen, da ihr 
Zweck im Definieren der Bedeutung derartiger Markierungen besteht. 

2) .BYTE. .DBYTE, TEXT, .WORD und V +N Pseudo-Operationen besitzen ge¬ 
wöhnlich Markierungen. 

3) .END sollte keine Markierung besitzen, da die Bedeutung einer derartigen 
Markierung unklar ist. 


ADRESSEN 


Der 6502-Assembler gestattet Eingaben in das Adres¬ 
senfeld in einer der folgenden Formen: 


Wir empfehlen, daß Sie Ausdrücke innerhalb des Adressenfeldes wenn immer 
möglichst vermeiden. Wenn Sie eine Adresse berechnen müssen, kommentie¬ 
ren Sie jeden unklaren Ausdruck und vergewissern Sie sich, daß die Auswertung 
der Ausdrücke niemals ein Resultat lietert, das zu groß für seine letzlliche An¬ 
wendung ist. 


ANDERE ASSEMBLER-EIGENSCHAFTEN 

Der Standard-6502-Assembler besitzt weder eine bedingte Assernblier-Möglich- 
keil noch eine Makro-Möglichkeit. Einige 6502-Assembler haben eine oder zwei 
dieser Möglichkeiten, und man sollte die Beschreibung dem entsprechenden 
Handbuch entnehmen. Wir werdenweilerhin keine dieser Möglichkeiten verwen¬ 
den oder uns hierauf beziehen, obwohl beide sehr bequem in praktischen An¬ 
wendungen sein können 


1) Dezimal (der Slandardfall) 

Beispiel: 1247 

2) Hexadezimal (muß beginnen mit $} 

Beispiel: SCEOO 

3) Oktal (muß beginnen mit @ ) 

Beispiel: @1247 

4) Binär (muß beginnen mit %) 

Beispiel: % 111 0001 1 

5) ASCII (einzelnes Zeichen, dem ein Apostroph vorausgehl) 
Beispiel: H 

6) Als eine Versetzung vom Befehlszähler (*) 

Beispiel: *+7 


ZAHLEN UND 
ZEICHEN IM 
ADRESSEN¬ 
FELD 


Die verschiedenen Adressler-Arten des 6502 werden wie 
folgt unterschieden: 


• Absolut oder Null-Seile (direkt) sind die Standard-Adressier Arten (der 
Assembler wählt die Null-Seite, wenn die Adresse kleiner als 256 ist, an¬ 
dernfalls die absolute). 

• #für unmittelbare Adressierung (geht den Daten voraus). 

• ,X oder ,Y für Indizierung (folgt der Versetzungs-Adresse). 

• Klammern um die Adresse werden indirekt veiwendel, so daß 

(addr.X) eine vor-indizierle (indizierte Adresse, indirekt verwendet) an- 
zeigl 

(addr),Y nach-indizierte (indirekte Adresse ist indiziert) anzeigl 
(addr) nur indirekte mit einem JPM-Befehl anzeigl. 

Bei den indizierten Adressier-Arten, wie bei den direkten Adressier-Aiten, wählt 
der Assembler automatisch die Nullseilen-Version, wenn dies zulässig ist und 
wenn die Adresse kleiner als 256 ist. 


Der Assembler gestattet auch Ausdrücke im Adressen¬ 
leid Die Ausdrücke bestehen aus Zahlen und Namen, ge¬ 
trennt durch die arithmetischen Operationen +, -, ‘(Multi¬ 
plikation) oder / (ganzzahlige Division). 

Der Assembler prüft die Ausdrücke von links nach rechts. Es sind weder Klam¬ 
mern zulässig um Operatione zu gruppieren, noch besteht irgendeine Rangfolge 
von Operationen. Gebrochene Ergebnisse werden gekürzt 


ARITHMETISCHE 
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Kapitel 4 

EINFACHE PROGRAMME 


Oer einzige Weg zum Erlernen der Programmierung in Assemblersprache ist 
das Schreiben von Assemblersprachen-Programmen. Die nächsten sechs 
Kapitel dieses Buches enthalten Beispiele für einfache Programme von 
typischen Mikrocomputer-Aufgaben. Sie sollten jedes Beispiel sorgfältig lesen 
und versuchen, diese Beispiele auf einem Mikrocomputer-System mit dem 
6502 auszuführen, um sich zu vergewissern, daß Sie den in dem Kapitel be¬ 
handelten Stoff auch verstanden haben. Schließlich sollten Sie die Aufgaben 
am Ende jedes Kapitels durcharbeiten und die sich ergebenden Programme 
ablaufen lassen. Dieses Kapitel enthält einige sehr einfache Programme. 


ALLGEMEINES FORMAT DER BEISPIELE 


Jedes Programm enthält folgende Teile: BEISPIEL¬ 

FORMAT 

1) Einen Titel, der die Aufgabe allgemein beschreibt. 

2) Eine Angabe des Zweckes, wobei die spezielle Aufgabe beschrieben wird, 
die das Programm ausführt, sowie die verwendeten Speicherplätze. 

3) Ein Programmbeispiel, das die Eingabedaten und die Ergebnisse zeigt 

4) Ein Flußdiagramm, wenn die Programmlogik komplex ist. 

5) Eine Auflistung des Programms in Form des Quellprogramms oder in 
Assemblersprache. 

6) Die Auflistung des Objektprogramms oder des Programmes in hexadezi¬ 
maler Maschinensprache. 

7) Erklärende Anmerkungen, mit denen die Befehle und die in dem Programm 
verwendeten Verfahren besprochen werden. 

Die Aufgaben am Ende des Kapitels sind ähnlich aufgebaut wie die 

Beispiele. Die Aufgaben sollten auf einem Mikrocomputer-System mit dem 

6502 programmiert werden, wobei die Beispiele als Richtlinie dienen. 

Das Quellprogramm in den Beispielen ist wie folgt aufgebaul: 


1) Es wird die Standard-Assembler-Schreibweise 
des 6502 verwendet, wie in Kapitel 3 
zusammengetaßt wurde. 

2) Die Form, in der Daten und Adressen aufscheinen, sind mehr nach ihrer 
Deutlichkeit ausgewählt, anstatt nach ihrer Folgerichtigkeit. Wir verwenden 
hexadezimale Zahlen für Speicheradressen, Befehlscodes und BCD-Daten. 
Für numerische Konstanten werden Dezimalzahlen verwendet, Binärzahlen 
für logische Masken und ASCII für Zeichen. 

3) Auf häufig verwendete Befehle und Programmier-Techniken wird besonderer 
Wert gelegt. 

4) Die Beispiele illustrieren die Aufgaben, die Mikroprozessoren in der Kommu¬ 
nikation, Instrumentation, Computertechnik, in Bürogeräten und industriellen 
und militärischen Anwendungen ausführen. 


RICHTLINIEN 
FÜR BEISPIELE 
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5) Es sind detaillierte Kommentare enthalten. 

6) Aut einfache und deutliche Struktur wird besonderer Weit gelegt, die Pro¬ 
gramme sind jedoch so effizient wie möglich innerhalb dieser Richtlinie. 
Die Anmerkungen beschreiben häufig effizientere Verfahren. 

7) Die Programme verwenden konsequente Speicher-Zuweisungen. Jedes 
Programm beginnt mit dem Speicherplatz 0000 und endet mit dem Break- 
Befehl (BRK). Wenn Ihr Mikrocomputer keinen Monitor und keine Unterbre¬ 
chungen besitzt, können Sie das Programm mit einem Befehl für eine end¬ 
lose Schleife beenden, wie etwa 

HERE JMP HERE 

Einige Mikrocomputer mit den 6502 können einen JMP- oder JSR-Befehl mit 
einer speziellen Bestimmungsadresse zur Steuerung des Monitors erfordern. 
Andere Mikrocomputer können eine Spezifikation der Monitor-Adresse be¬ 
nötigen, die mit dem BRK-Befehl zu verwenden ist Wenn Sie beispielsweise 
den populären KIM-1 verwenden, müssen Sie 1C00 in die Adressen 17FE und 
17FF laden. Achten Sie jedoch darauf; die 00 muß in die Adresse 17FE und IC 
in die Adresse 17FF geladen werden. Wir werden später erklären, wie der 
6502 Adressen speichert und wie er den BRK-Befehl ausführt (siehe Kapitel 
12 ). 

Schlagen Sie im Anwender-Handbuch Ihres Mikrocomputers nach, um die er¬ 
forderlichen Speicherzuweisungen und Abschlußbefehle für Ihr spezielles 
System zu bestimmen. 

RICHTLINIEN ZUR LÖSUNG VON AUFGABEN 

Verwenden Sie die folgenden Richtlinien zur Lösung der Aufgaben am Ende 
Jedes Kapitels: 


1) Kommentieren Sie jedes Programm so. daß andere es 
verstehen können. Die Kommentare können kurz und 
ungrammatisch sein. 

Sie sollen den Zweck eines Abschnittes oder Befehls im Programm erklären. 
Kommentare sollten nicht die Arbeitsweise von Befehlen beschreiben, der¬ 
artige Beschreibungen sind in den Handbüchern enthalten. Man braucht 
nicht jede Anweisung zu kommentieren oder erklären, wenn diese offensicht¬ 
lich sind. Man kann dem Format der Beispiele folgen, braucht jedoch nicht so 
sehr ins Detail zu gehen. 

2) Bevorzugen Sie Klarheit, Einfachheit und einen guten Aufbau der 
Programme. Wenn auch Programme möglichst effizient sein sollen, so ist es 
jedoch nicht unbedingt erforderlich, ein einzelnes Wort oder einen Pro¬ 
grammspeicherplatz oder einige wenige Mikrosekunden einzusparen. 

3) Machen Sie Programme einigermaßen universell, verwechseln Sie nicht 
Parameter (wie etwa die Nummer eines Elements in einer Anordnung) mit 
festen Konstanten (wie etwa n oder ASCII C), 

4) Nehmen Sie niemals feste Anfangswerte für Parameter an. d.h. verwenden 
Sie einen Befehl zum Laden eines Anfangswertes in einen Parameter. 

5) Verwenden Sie Assembler-Schreibweise, wie sie in den Beispielen gezeigt 
wird und in Kapitel 3 definiert wurde. 


6) Verwenden Sie hexadezimale Schreibweise für Adressen. Verwenden Sie 
die deutlichste Form für Daten. 

7) Wenn Ihr Mikrocomputer es gestattet, beginnen Sie alle Programme Im 
Speicherplatz 0000 und verwenden Sie Speicherplätze beginnend mit 0040 
für Daten und zeitweilige Speicherung. Andernfalls richten Sie äquivalente 
Adressen für Ihren Mikrocomputer ein und verwenden Sie diese konse¬ 
quent. Die Einzelheiten entnehmen Sie Ihrem Handbuch. 

8) Verwenden Sie bedeutungsvolle Namen für Marken und Variable. Zum Bei¬ 
spiel SUM oder CHECK anstatt X, Y. oder Z 

9) Führen Sie jedes Programm auf Ihrem Mikrocomputer aus Es gibt keinen 
anderen Weg sich zu vergewissern, daß Ihr Programm korrekt ist. Es wurden 
bei jeder Aufgabe Daten als Beispiele vorgesehen. Vergewissern Sie sich, 
daß das Programm auch für spezielle Fälle arbeitet. 

Wir wollen nun einige nützfiche Informationen zusammenfassen, an die man 
sich beim Schreiben von Programmen erinnern soll. 

In nahezu allen Verarbeitungs-Befehlen (z,B. 

Add, Subtract, AND. OR) verwenden Sie den In¬ 
halt des Akkumulators als einen Operanden 
und speichern die Ergebnisse zurück in den Akkumulator. In den meisten Fällen 
werden Sie die ursprünglichen Daten in den Akkumulator mit LDA laden. Sie 
werden in den meisten Fällen das Ergebnis vom Akkumulator in den Speicher 
mit STA speichern. _ 


Daten, auf die häufig zugegriffen wird, oder 
Basis-Adressen und Zeiger sollten auf die Null¬ 
seite (page zero) des Speichers plaziert werden. 

Auf diese Daten kann dann mit Null-Seiten- (direkter) 

Seiten-indizierter Adressierung zugegriffen werden 

Beachten Sie speziell, daß sowohl Vor-Indizieren wie Nach-Indizieren, beide an¬ 
nehmen, daß eine Adresse auf der Nullseile gespeichert ist Die direkte und indi¬ 
zierte Adressier-Art für die Nullseite benötigen beide weniger Zeit und Speicher, 
als die entsprechenden absoluten Adressier-Arten. 

Einige Befehle wie Verschieben, Inkrementieren (Addieren von 1) und Dekre- 
mentieren (Subtrahieren von 1) können direkt auf die Daten im Speicher arbei¬ 
ten. Derartige Befehle gestatten Ihnen, an den Anwender-Registern vorbei zu 
gehen, benötigen jedoch zusätzliche Ausführungszeit, da die Daten in Wirklich¬ 
keit in die CPU geladen und die Ergebnisse in den Speicher zurückglegt werden 
müssen. 


PROGRAMMIER¬ 
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PROGRAMM-BEISPIEL 

8-Bit-Datentransfer 

Zweck: Bringe den Inhalt des Speicherplatzes 0040 zum Speicherplatz 0041 

Beispiel: 

(0040)-6A 
Ergebnis: (0041) = 95 

Quellprogramm: 


LDA 

$40 

;HOLE DATEN 

STA 

$41 

TRANSFERIERE ZU NEUEM 



; SPEICHERPLATZ 

BRK 




Objektprogramm: 


Speicher Adresse 
(Hex) 

Speicher Inhalt 
(Hex) 

Befehl 

(Mnemonik) 

0000 

A5 

LDA $40 

0001 

40 


0002 

85 

STA $41 

0003 

41 


0004 

00 

BRK 


LDA (Load Accumulator) und STA (Store Accumulator) benötigen eine Adresse 
zur Bestimmung der Quelle oder des Bestimmungsortes der Daten Da die in 
diesem Beispiel verwendeten Adressen auf Seite Null liegen (d.h., die acht 
höchstwertigen Bits sind alles Nullen), kann die (direkte) Null-Seiten-Form der 
Befehle mit der Adresse im nächsten Wort verwendet werden. Die führenden 
Nullen können weggelassen werden Die Adressen sind in Wirklichkeit 0040 und 
0041, es kann jedoch die abgekürzte Form verwendet werden, wie es auch im 
Alltagsleben üblich ist (zB., sagt man "sechzig Pfennig" und nicht "null Mark und 
sechzig Pfennig"). 

BRK (Force Break) wird am Ende aller Beispiele verwendet und gibt die Steuer¬ 
ung zum Monitor zurück. Erinnern Sie sich daran, daß Sie gegebenfalls einen 
entsprechenden Befehl für Ihren Mikrocomputer verwenden müssen 


8-Bit-Addition 

Zweck: Addiere den Inhalt der Speicherplätze 0040 und 0041, und plaziere das 
Ergebnis in den Speicherplatz 0042 


Beispiel: 

(0040) = 38 
(0041) = 2B 


Ergebnis: 

(0042) - 63 


Quellprogramm: 

CLC 


;LÖSCHE ÜBERTRAG ZU BEGINN 

LDA 

$40 

;HOLE ERSTEN OPERANDEN 

ADC 

$41 

iADDIERE ZWEITEN OPERANDEN 

STA 

BRK 

$42 

;SPEICHERE ERGEBNIS 


Objektprogramm: 


Speicher Adresse 
(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) 

0000 

18 

CLC 


0001 

A5 

LDA 

$40 

0002 

40 



0003 

65 

ADC 

$41 

0004 

41 



0005 

85 

STA 

$42 

0006 

42 



0007 

00 

8RK 



Der einzige Additionsbefehl des Mikroprozessors 6502 ist ADC (Addiere mit 
Übertrag), der in (A)=(A) +(M) + (Übertrag) resultiert, wobei M der adressierte 
Speicherplatz ist. Wir benötigen daher anfangs den Befehl CLC (Lösche Über¬ 
trag), wenn der Wert des Übertrags nicht die Addition beeinflussen soll. Erinnern 
Sie sich daran, daß der Übertrag in allen Additionen und Subtraktionen enthal¬ 
ten ist. 

Die Nullseilen-Form (direkte) aller Befehle wird verwendet, da die Adressen in 
den ersten 256 Bytes des Speichers liegen. 

ADC beeinflußt das Übertragsbit, LDA und STA dagegen nicht. Nur arithmeti¬ 
sche und Schiebebefehle beeinflussen den Übertrag, logische und Transfer- 
Befehle nicht. 

LDA und ADC beeinflussen den Inhalt des Speicherplatzes nicht STA ändert 
den Inhalt des addressierten Speicherplatzes, hat jedoch keinen Einfluß 
auf den Inhalt des Akkumulators. 
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Vergewissern Sie sich, daß das Flag für die Dezimai-Belriebsarl (D) gelöscht ist, 
wenn Sie dieses Programm ausführen. Um absolul sicher zu sein, daß sich das 
D-Fiag im richtigen Zustand befindet, könnten Sie einen CLD-Befehl (D8, 6 ) 
beim Beginn des Programmeseinsetzen, Wenn Sie einen Mikrocomputer KIM-1 
verwenden, sollten Sie den Speicherplatz OOF1 löschen, um sicher zu sein, daß 
das Flag für die Dezimai-Belriebsart Ihr Programm oder den Monitor 
nicht stört. 


Ausmaskieren der höchswertigen vier Bits 

Zweck: Plaziere die niedrigstwertigen vier Bits des Speicherplatzes 0040 in die 
niedrigstwertigen vier Bits des Speicherplatzes 0041, Lösche die 
höchstwertigen vier Bits des Speicherplatzes 0041. 

Beispiel: 


(0040) = 3D 
Ergebnis: (0041) = 0D 


Verschieben um ein Bit nach links 

Zweck: Verschiebe den Inhalt des Speicherplatzes 0040 um ein Bit nach links 
und plaziere das Ergebnis in den Speicherplatz 0041. Lösche die leere 
Bit-Position. 


Queliprogramm: 

LDAA $40 ;HOLE DATEN 

AND #%00001111 ;MASKIERE DIE VIER MSBs 
STA $41 SPEICHERE ERGEBNIS 

BRK 


Beispiel: 

(0040) - 6F 


Ergebnis: 

(0041) - DE 


Quellprogramm: 

LDA 

$40 

.HOLE DATEN 

ASL 

A 

.VERSCHIEBE NACH LINKS 

STA 

BRK 

$41 

iSPEICHERE ERGEBNIS 


Objektprogramm: 


Speicher-Adresse 

(Hex) 

Speicher-Innall 

(Hex) 

Befehl 

(Mnemonik) 

0000 

A5 

LDA $40 

0001 

40 


0002 

OA 

ASL A 

0003 

85 

STA $41 

0004 

41 


0005 

00 

BRK 


Der Befehl ASL A verschiebt den Akkumulalor um ein Bit nach links und löscht 
das niedrigstwertige Bit. Das höchstwertige Bit gelangt in den Übertrag. Das Er¬ 
gebnis ist das Zweifache der ursprünglichen Daten (warum?). 

Beachten Sie, daß wir auch den Inhalt des Speicherplatzes 0040 um ein Bit mit 
dem Befehl ASL $40 verschieben und dann das Ergebnis zum Speicherplatz 
0041 bringen könnten Dieses Verfahren würde jedoch den Inhalt des Speicher¬ 
platzes 0040 ändern, sowie den Inhalt des Speicherplatzes 0041. 


Anmerkung: # bedeutet unmittelbare Adressierung und % bedeutet binäre Kon¬ 
stante in der Standard-Assembler-Schreibweise des 6502. 


Objektprogramm: 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) 

0000 

A5 

L#A 

$40 

0001 

40 



0002 

29 

AND 

#%00001111 

0003 

0F 



0004 

85 

STA 

$41 

0005 

41 



0006 

00 

BRK 



AND # %00001111 UNDiert logisch den Inhalt des Akkumulators mit der Zahl 
OF,e, nicht den Inhalt des Speicherplatzes 000F Unmittelbare Adressierung 
(angezeigt durch #) bedeutet, daß die tatsächlichen Daten, nicht die Adresse 
der Daten, im Befehl enthalten ist. 

Die Maske (00001 111) wird in binär geschrieben, um ihren Zweck für den Leser 
deutlicher zu machen. Die binäre Schreibweise für Masken ist klarer als hexade¬ 
zimale Schreibweise, da logische Operationen eher Bit für Bit ausgeführt wer¬ 
den, anstall an Ziffern oder Bytes gleichzeitig. Das Ergebnis hängt natürlich 
nicht von der Programmier-Schreibweise ab. Hexadezimale Schreibweise sollte 
für Masken verwendet werden, die größer als 8 Bits sind, da dann die binäre 
Version lang und unübersichtlich wird. Die Kommentare sollten die Maskier- 
Operationen beschreiben. 

Ein logischer AND Befehl kann zum Löschen von Bits dienen, die nicht verwen¬ 
det werden. Zum Beispiel könnten die vier niedrigstwertigen Bits von Daten 
eine Eingabe von einem 10-poligen Schalter sein, oder eine Ausgabe zu einer 
numerischen Anzeige, 
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Löschen eines Speicherplatzes 


Zerlegung eines Wortes 


Zweck: Lösche den Speicherplatz 0040. 

Quellprogramm: 

LOA # 

STA $40 ;LÖSCHE SPEICHERPLATZ 40 

BRK 


Zweck: Teile den Inhalt des Speicherplatzes 0040 in zwei 4-Bit-Ab- 
schnille auf und speichere sie in die Speicherplätze 0041 und 
0042 Plaziere die vier höchstwertigen Bits des Speicherplatzes 
0040 in die vier niedrigstwertigen Bit-Positionen des Speicher¬ 
platzes 0042. Lösche die vier höchstwertigen Bit-Positionen der 
Speicherplätze 0041 und 0042. 

Beispiele: 


Objektprogramm: 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) 

0000 

A9 

LDA #0 

0001 

00 


0002 

85 

STA $40 

0003 

40 


0004 

00 

BRK 


Null wird nicht anders als andere Zahlen behandelt - der 6502 hat keinen spe¬ 
ziellen Löschbefehl, Erinnern Sie sich jedoch daran daß LDA #0 das Nullflag 
auf eins setzt. Beachten Sie immer diese Logik- das Z (Zero)-Flag wird auf eins 
gesetzt, wenn das letzte Ergebnis null war 

STA beeinflußt keinerlei Status-Flags. 


Ergebnis: 

Quellprogramm: 


(0040) = 3F 
(0041) - 03 
(0042) - 0F 


LDA 

AND 

STA 

LDA 

LSR 

LSR 

LSR 

LSRA 

STA 

BRK 


$40 

#%00001111 

$42 

$40 

A 

A 

A 

A 

$41 


HOLE DATEN 

MASKIERE VIER MSBs AUS 
SPEICHERE LSBs 
SPEICHERE DATEN ZURÜCK 
VERSCHIEBE DATEN 4 MAL LOGISCH 
NACH RECHTS 


iSPEICHERE MSBs 


Objektprogramm: 


Speicher Adresse 
(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) 

0000 

A5 

LDA 

$40 

0001 

40 



0002 

29 

AND 

#%0000 1111 

0003 

OF 



0004 

85 

STA 

$42 

0005 

42 



0006 

A5 

LDA 

$40 

0007 

40 



0008 

4A 

LSR 

A 

0009 

4A 

LSR 

A 

000A 

4A 

LSR 

A 

0008 

4A 

LSR 

A 

oooc 

85 

STA 

$41 

000D 

41 



000E 

00 

BRK 
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Eine logische Verschiebung um vier Positionen erfordert vier Ausführungen des 
LSR A-Befehls. 

Jeder LSR-Befehl löscht das höchstwertige Bit des Ergebnisses. Daher werden 
die vier höchstwertigen Bits des Akkumulators alle gelöscht, wenn LSR A vier¬ 
mal ausgeführt wurde. 

Sie könnten vielleicht wünschen, das Programm neu zu schreiben, so daß eine 
Kopie der Daten im Indexregister X aufbewahrt, anstatt die gleichen Daten zwei¬ 
mal zu laden. Welche Version würden Sie vorziehen und weshalb? 


Finden der größeren von zwei Zahlen 

Zweck: Plaziere den größeren Inhalt der Speicherplätze 0040 und 0041 in den 
Speicherplatz 0042. Nimm an, daß der Inhalt der Speicherplätze 0040 
und 0041 Binärzahlen ohne Vorzeichen sind. 


Beispiel: 

a. 

(0040) - 3F 
(0041) - 2B 


Ergebnis: 

(0042) - 3F 


b. 

(0040) - 75 
(0041) - AB 


Ergebnis: 

(0042) - AB 


Quellprogramm: 

LDA 

$40 

;HOLE DEN ERSTEN OPERANDEN 

CMP 

$41 

;IST ZWEITER OPERAND GRÖSSER? 

BCS 

STRES 


LDA 

$41 

;JA HOLE STATTDESSEN ZWEITEN OPER 
, ANDEN 

STRES STA 
BRK 

$42 

;SPEICHERE GRÖSSEREN OPERANDEN 


Objektprogramm: 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) 

0000 

A5 

LDA 

$40 

0001 

40 



0002 

C5 

CMP 

$41 

0003 

41 



0004 

B0 

BCS 

STRES 

0005 

02 



0006 

A5 

LDA 

$41 

0007 

41 



000B 

B5 

STRES STA 

$42 

0009 

42 



000A 

00 

BRK 



CMP $41 subtrahiert den Inhalt des Speicherplatzes 0041 vom Inhall des Akku¬ 
mulators, speichert das Ergebnis jedoch nicht irgendwohin. Der Befehl wird aus¬ 
schließlich zum Setzen der Flags für eine folgende bedingte Verzweigung 
verwendet. 

CMP beeinflußt die Fiags wie folgt: 

1) N nimmt den Wert des höchstwertigen Bits des Ergebnisses der Subtraktion 
an. 

2) Z wird 1, wenn das Ergebnis der Subtraktion 0 ist, andernfalls wird es 0. 

3) C wird auf 1 gesetzt, wenn die Subtraktion kein "Borgen" benötigt und auf 0. 
wenn dies der Fall ist. Beachten Sie, daß C ein invertiertes Borgen ist, nicht 
das tatsächliche Borgen, wie bei zahlreichen anderen Mikroprozessoren 

4) V wird nicht beeinflußt. 

Beachten Sie folgende Fälle: 

1) Wenn die Operanden gleich sind, so ist Z - 1. Wenn sie nicht gleich sind, so 
ist Z - 0. 

2) Wenn der Inhalt des Akkumulators größer oder gleich wie der Inhalt der an¬ 
deren Adresse ist (vorausgesetzt, daß beide Binärzahlen ohne Vorzeichen 
sind), so ist C - 1, da dann kein Borgen erforderlich wäre. Andernfalls ist C - 
0 . 

Alle Befehle des 6502 für eine bedingte Verzweigung verwenden die relative 
Adressierung, bei der das zweite Wort des Befehls eine 8-Bit-Zweierkomple- 
ment-Zahl ist, die die CPU zur Adresse des nächsten Befehls addiert, um die 
Ziel-Adresse zu finden, in diesem Beispiel ist die relative Versetzung gleich 
0008 (Ziel-Adresse) - 0006 (Adresse, die unmittelbar der Verzweigung folgt) 
oder 02. 

Offensichtlich ist das Berechnen von relativen Versetzungen sehr fehleranfällig, 
speziell wenn das Ergebnis negativ ist. Wenn Sie jedoch alle Ziel-Befehle mar¬ 
kieren, wird der Assembler die Berechnungen für Sie ausführen. 

BCS bewirkt eine Verzweigung, wenn der Übertrag 1 ist. Ist der Übertrag 0, so 
setzt der Prozessor die Ausführung der Befehle in seiner normalen Sequenz 
fort, so als ob der Verzweigungs-Befehl nicht existieren würde. 

STRES ist eine Marke (Label), ein Name, den der Programmierer einer Speicher- 
Adresse zuweist, so daß man sich an diese leichter erinnern und sie lokalisieren 
kann. Beachten Sie, daß Markierungen von einem Zwischenraum auf der Zeile 
gefolgt werden, auf der sie definiert werden. Oie Markierung macht den Zielort 
einer Verzweigung deutlich, speziell wenn relative Adressierung verwendet wird 

Die Verwendung einer Marke ist zu empfehlen, um vor allem die Versetzung zu 
spezifizieren (d.h. BCS*+4), da die Befehle des 6502 unterschiedliche Länge be¬ 
sitzen. Ein anderer Anwender könnte deshalb leicht einen Fehler bei der Bestim¬ 
mung einer Versetzung machen. 
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1 6-Bit-Addition 

Zweck: Addiere die 16-Bit-Zahl in den Speicherplätzen 0040 und 0041 zur 
16-Bit-Zahl in den Speicherplätzen 0042 und 0043. Die höchstwertigen 
acht Bits befinden sich in den Speicherplätzen 0041 und 0043. Spei¬ 
chere das Ergebnis in die Speicherplätze 0044 und 0045, mit den 
höchstwertigen Bits in 0045 

Beispiel: 

(0040) - 2A 
(0041) - 67 
(0042) - F8 
(0043) - 14 

Resultat:672A + 14F8 - 7C22 

(0044) - 22 
(0045) - 7C 

Quellprogramm: 


CLC 


;LÖSCHE ÜBERTRAG ZU BEGINN 

LDA 

$40 

iADDIERE DIE NIEDRIGSTWERTIGEN BITS 

ADC 

$42 


STA 

$44 


LDA 

$41 

iADDIERE DIE HÖCHSTWERTIGEN BITS MIT 

1 ÜBERTRAG 

ADC 

$43 


STA 

BRK 

$45 



Objektprogramm: 


Speicheradresse 

(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) 

0000 

18 

CLC 


0001 

A5 

LDA 

$40 

0002 

40 



0003 

65 

ADC 

$42 

0004 

42 



0005 

85 

STA 

$44 

0006 

44 



0007 

A5 

LDA 

$41 

0008 

41 



0009 

65 

ADC 

$43 

000A 

43 



0006 

85 

STA 

$45 

oooc 

45 



000D 

00 

BRK 



Sie müssen den Übertrag vor der ersten Addition löschen, da es niemals einen 
Übertrag in die niedrigstwertigen Bits gibt 

ADC beinhaltet dann automatisch den Übertrag von den niedrigstwertigen Bits 
in die Addition der höchstwertigen Bits. Der Mikroprozessor kann daher Daten 
jeder beliebigen Länge addieren. Er addiert Zahlen mit acht Bits gleichzeitig, 
wobei die Ubertrags-Inlormation von einem 8-Bit-Abschmtt zum nächsten über¬ 
tragen wird Beachten Sie jedoch, daß jede 8-Bit Addition die Auslührung von 
drei Befehlen (LDA, ADC, STA) erfordert, da es nur einen Akkumulator gibt 
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Tabelle der Quadrate 


Objektprogramm: 


Zweck: Berechne das Quadrat des Inhalts des Speicherplatzes 0041 aus einer 
Tabelle und plaziere ihn in den Speicherplatz 0042. Es wird angenom¬ 
men. daß der Speicherplatz 0041 eine Zahl zwischen 0 und einschließ¬ 
lich 7 enthält. (0 < (0041) « 7) 


Diese Tabelle besetzt die Speicherplätze 0050 bis 0057. 


Speicher-Adresse 

(Hex) 

Eingabe 

(Hex) 

(Dezimal) 


00 

0 (o|> 


01 

1 <1,1 


04 

4 


09 

9 C3f> 

0054 

10 

16 (4‘! 


19 

25 <5,1 


24 

36 16,) 

0057 

31 

49 ün 


Beispiel: 


a. 

(0041) - 03 

Ergebnis: 

(0042) - 09 

b. 

(0041) - 06 

Ergebnis: 

(0042) - 24 

Erinnern Sie sich daran, daß das Ergebnis eine Hexadezimal-Zaht ist. 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) 

0000 

A6 

LDX 

$41 

0001 

41 



0002 

B5 

LDA 

$50.X 

0003 

50 



0004 

85 

STA 

$42 

0005 

42 



0006 

00 

BRK 


0050 

00 

SQTAB BYTE 

0 

0051 

01 


1 

0052 

04 


4 

0053 

09 


9 

0054 

10 


16 

0055 

19 


25 

0056 

24 


36 

0057 

31 


49 


Beachten Sie, daß Sie auch die Tabelle der Quadrate in den Speicher eingeben 
müssen (die Assembler-Pseudo-Operation BYTE wird dies durchführen). Die 
Tabelle der Quadrate sind konstante Daten, nicht Parameter, die sich ändern 
können. Deshalb können Sie die Tabelle initialisieren, indem Sie die Byte- 
Pseudo-Operalion verwenden, anstatt Befehle auszuführen, um Werte in die Ta¬ 
belle zu laden. Erinnern Sie sich daran, daß in praktischen Anwendungen, die 
Tabelle ein Teil des Festwertspeichers sein würde. Die BYTE-Pseudo-Operation 
ptaziert die spezifizierten Daten in den Speicher in der Reihenfolge, in der sie im 
Operandenfeld aufscheinen. 


Quellprogramm: 


SOTAB 


LDX 

$41 

LDA 

$50,X 

STA 

$42 

BRK 


*-$50 


BYTE 

0,1,4,9,16.25,36,49 


HOLE DATEN 

HOLE QUADRAT DER DATEN 
SPEICHERE QUADRAT 

;QUADRAT-TABELLE 


Die Pseudo-Operation *= bestimmt einfach, wo der Lader (oder Assembler) den 
nächsten Abschnitt des Codes plazieren wird, wenn er schließlich in den Spei¬ 
cher des Mikroprozessors für die Ausführung eingegeben wird. Beachten Sie, 
daß die Pseudo-Operation niemals wirklich in einem zu erzeugenden Objekt¬ 
code resultiert. 

Indizierte Adressierung (oder Indizieren) bedeutet, daß die vom Befehl verwen¬ 
dete tatsächliche Adresse die Summe der Adresse ist. die im Befehl enthalten 
ist (häutig als effektive Adresse bezeichnet) und dem Inhalt des Indexregisters. 
Daher ist LDA S50.X (.X oder ,Y zeigt indizierte Adressierung in der Assembler¬ 
sprache des 6502 an) gleich ist mit LDA $50 + (X), oder LDA $53, wenn (X) - 03. 
In diesem Programm-Beispiel enthält das Indexregister X die zu quadrierende 
Zahl, und die Adresse, die in diesem Befehl eingeschlossen ist und stellt die 
Start-Adresse der Tabelle der Quadrate dar. 


Beachten Sie, daß es eine spezielle indizierte Nullseiten-Adressierung unter 
Verwendung des Indexregisters X gibt. 


Indizierung benötigt immer zusätzliche Zeit, da der Mikrocomputer eine Addi¬ 
tion zur Berechnung der effektiven Adresse ausführen muß. Daher erfordert LDA 
$50,X vier Takt-Zyklen, während LDA $50 nur drei braucht Es würde jedoch of¬ 
fensichtlich wesentlich mehr Zeit erfordern, um auf die Tabellen-Eingabe zuzu¬ 
greifen. wenn der Mikroprozessor kein Indizieren besäße und die Adressen- 
Berechnung mit einer Serie von Befehlen auszuführen wäre. 
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Erinnern Sie sich daran, daß die Indexregister nur 0 Bits lang sind, so daß die 
maximale Versetzung von der Basis-Adresse 255 (FFi S ) beträgt. Beachten Sie 
auch, daß die Versetzung eine Zahl ohne Vorzeichen ist (anders als die Ver¬ 
setzung bei der relativen Adressierung), so daß sie niemals negativ sein kann. 

Es gibt einige wenige spezielle Belehle, die aul eines der Indexregister arbeiten, 
anslall auf einen Akkumulator. Diese sind: 


CPX, CPY-Vergleiche Speicher und Indexregister 
DEX, DEY- Dekrementiere Indexregister (um 1) 

INX, INY -Inkrementiere Indexregister (um 1) 

LDX, LDY - Lade Indexregister vom Speicher 
STX, STY -Speichere Indexregister in Speicher 
TAX, TAY- Transfenere Akkumulator zu Indexregister 
TXA, TYA -Transferiere Indexregister zu Akkumulator 


Erinnern Sie sich daran, daß es nur einige wenige Adressier-Arten mit CPX, 
CPY, LDX, LDY, STX und STY gibt. Sehen Sie sich Tabelle 3-4 für weitere Details 


Arithmetische Aufgaben, die ein Mikroprozessor nicht di- 

rekt mit einigen wenigen Befehlen ausführen kann, werden TABELLEN 

häufig am besten mit "Nachschlage'-Tabellen ausgeführt. - CLUC - 

Nachschlage-Tabellen (lookup tables) enthalten einfach alle möglichen Antwor¬ 
ten für eine Aufgabe. Sie sind so organisiert, daß die Lösung einer speziellen 
Aufgabe leicht gefunden werden kann Die arithmetische Aufgabe wird nun zu 
einer Zugritt-Aufgabe: Wie kann man die richtige Antwort aus der Tabelle erhal¬ 
ten? Wir müssen zwei Dinge wissen: Die Lage oder Position der Antwort in der 
Tabelle (genannt der Index) und die Basis- oder Start-Adresse der Tabelle. Die 
Adresse der Antwort ist dann die Basis-Adresse plus dem Index. 


Die Basis-Adresse ist natürlich eine feste Zahl für eine bestimmte Tabelle. Wie 
kann man nun den Index bestimmen? In einfachen Fällen, bei denen nur kurze 
Daten verwendet werden, kann man die Tabelle so organisieren, daß die Daten 
den Index darstellen. In der Tabelle der Quadrate enthält die "nullte" Eingabe in 
die Tabelle Null zum Quadrat, die erste Eingabe Eins zum Quadrat usw. In kom¬ 
plexeren Fällen, bei denen eine größere Vielfalt von Eingangswerten vorhanden 
ist, oder wo verschiedene Arten von Daten Vorkommen (z.B. Wurzeln einer qua¬ 
dratischen Gleichung oder Anzahl der Permutationen) muß man kompliziertere 
Verlahren zur Bestimmung der Indizes vei'wenden. 

Der grundlegende Vorteil bei der Verwendung einer Tabelle liegt in der Einspa¬ 
rung der Zeit, wobei jedoch mehr Speicherplätze benötigt werden. Tabellen sind 
schneller, da keine Berechnungen erforderlich sind und einfacher, da keine ma¬ 
thematischen Methoden abgeleitet und getestet werden müssen. Tabellen kön¬ 
nen jedoch viel Platz im Speicher belegen, wenn der Bereich der Eingangsdaten 
groß ist. Man kann häulig die Größe einer Tabelle verringern, indem man die 
Genauigkeit der Ergebnisse reduziert, durch Skalieren der Eingangsdaten, oder 
einer geschickten Organisation der Tabelle Tabellen werden häufig zur Berech¬ 
nung transdezenter und trigonometrischer Funktionen verwendet, zur Linerari¬ 
sierung von Eingangswerten, zur Umwandlung von Codes und zur Ausführung 
anderer mathematischer Aufgaben. 
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Einerkomplement 


Zweck: Komplementiere logisch den Inhalt des Speicherplatzes 0040 und pla¬ 
ziere das Ergebnis in den Speicherplatz 0041. 

Beispiel: 


Ergebnis: 

(0040)-A 
(0041) >95 


Quellprogramm: 

LDA 

$40 

;HOLE DATEN 

EOR 

#% 11111111 

KOMPLEMENTIERE DATEN LOGISCH 

STA 

$41 

iSPEICHERE ERGEBNIS 

BRK 




Objektprogramm: 


Speicher Adresse 

Speicher-Inhalt 

Belehl 

(Hex) 

(Hex) 

(Mnemonik) 

0000 

A5 

LDA 

$40 

0001 

40 


0002 

49 

EOR 

#%11111111 

0003 

FF 


0004 

85 

STA 

$41 

0005 

41 


0006 

00 

BRK 



Dem Mikroprozessor 6502 fehlen einige einfache Befehle, wie Löschen oder 
Komplementieren, die in den meisten übrigen Befehlssätzen enthalten sind. Die 
erforderlichen Operationen können jedoch mit den bestehenden Befehlen leicht 
ausgeführt werden, wenn man einige einfache Tricks anwendet. 

Exklusiv-ODERieren eines Bits mit”1" komplementiert das Bit, da 

1 -V- 0= 1 


Aut diese Weise verwandelt die Exklusiv-ODER-Funktion jedes 0-Bit in eine 1 
und ein 1-Bit in eine 0, so daß dies einem logischen Komplementieren oder In¬ 
vertieren entspricht. Beachten Sie jedoch, daß der Befehl EOR #%11111111 
zwei Speicherbytes belegt, eines für den Operationscode und eines lür die 
Maske. Ein spezieller Komplementier Befehl würde nur ein Byte benötigen. 

Ein Problem mit dieser Lösung besteht darin, daß der Zweck des Belehls nicht 
unmittelbar zu ersehen ist. Ein Leser würde wahrscheinlich überlegen, was eine 
Exklusiv-ODER-Funktion mit einem Wort aus lauter Einsen wirklich ausführt. 
Eine entsprechende Dokumentation ist hier sehr wesentlich, und die Verwen¬ 
dung von Makros kann ebenfalls zum Klären der Situation beitragen. 
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AUFGABEN 

1) 16-Bit-Daten-Transfer 

Zweck: Bringe den Inhalt des Speicherplatzes 0040 zum Speicherplatz 
0042 und den Inhalt des Speicherplatzes 0041 zum Speicherplatz 
0043. 

Beispiel: 

(0040) -3E 
(0041)-87 
Ergebnis: (0042)-3E 

(0043)-B7 

2) 8-Bit-Subtraktion 

Zweck: Subtrahiere den Inhalt des Speicherplatzes 0041 vom Inhalt des 
Speicherplatzes 0040. Plaziere das Ergebnis in den Speicherplatz 
0042. 

Beispiel: 

(0040)-77 
(0041)-39 
Ergebnis: (0042)-3E 

3) Verschiebe um zwei Bits nach links 

Zweck: Verschiebe den Inhalt des Speicherplatzes 0040 nach links um zwei 
Bits und plaziere das Ergebnis in den Speicherplatz 0041. Lösche die 
beiden niedrigstwertigen Bit-Positionen 


6) Wort-Zusammensetzung 

Zweck: Kombiniere die vier niedrigstwertigen Bits der Speicherplätze 0040 
und 0041 zu einem Wort und speichere dieses in den Speicherplatz 
0042. Plaziere die vier niedrigstwertigen Bits des Speicherplatzes 0040 
in die vier höchstwertigen Bit-Positionen des Speicherplatzes 0042. 
Plaziere die vier niedrigstwertigen Bits des Speicherplatzes 0041 in die 
vier niedrigstwertigen Bit-Positionen des Speicherplatzes 0042 

Beispiel: 



(0040) 

- 6A 


(0041) 

- B3 

Ergebnis: 

(0042) 

- A3 


7) Auffinden der kleineren von zwei Zahlen 

Zweck: Plaziere den kleineren Inhalt der Speicherplätze 0040 und 0041 in den 
Speicherplatz 0042. Nimm an, daß 0040 und 0041 Binärzahlen ohne 
Vorzeichen enthalten. 


Beispiel: 

a. 

(0040) - 3F 

Ergebnis: 

(0041) - 2B 
(0042) - 2B 

b. 

(0040) - 75 


(0041) _ A8 

Ergebnis: 

(0042) - 75 

8) 24-Bit-Addition 


Beispiel: 

(0040) - 5D 
Ergebnis: (0041)-74 

4) Maskiere die niedrigstwertigen vier Bits aus 


Zweck: Addiere die 24-Bit-Zahl in den Speicherplätzen 0040. 0041 und 
0042 zu der 24-Bit-Zahl in den Speicherplätzen 0043, 0044 und 
0045. Die höchstwertigen 8 Bits befinden sich in den Speicherplät¬ 
zen 0042 und 0045, die niedrigstwertigen 8 Bits in den Speicher¬ 
plätzen 0040 und 0043. Speichere das Ergebnis in die Speicher¬ 
plätze 0046, 0047 und 0048 mit den höchstwertigen Bits in 0048 
und den niedrigstwertigen Bits in 0046. 


Zweck: Plaziere die vier höchstwertigen Bits des Inhalts des Speicherplatzes 
0040 in den Speicherplatz 0041. Lösche die vier niedrigstwertigen 
Bits des Speicherplatzes 0041. 

Beispiel: 


(0040) -C4 
Ergebnis: (0041)-C0 

5) Setze einen Speicherplatz auf Einsen 

Zweck: Der Speicherplatz 0040 wird auf lauter Einsen (FF, e ) gesetzt. 


Beispiel: 

(0040) - 2A 
(0041) - 67 
(0042) - 35 
(0043) - F8 
(0044) - A4 
(0045) - 51 
Ergebnis: (0046) - 22 

(0047) - 0C 
(0048) - 87 

das heißt: 35672A 
+51A458 
870C22 
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9) Summe der Quadrate 

Zweck: Berechne die Quadrate des Inhaltes der Speicherplätze 0040 und 0041 
und addiere sie. Plaziere das Ergebnis in den Speicherplatz 0042. Nimm 
an, daß die beiden Speicherplätze 0040 und 0041 Zahlen zwischen 0 
und einschließlich 7 enthalten (0^(0040)^7 und 0^(0041)^7). Ver¬ 
wende die Tabelle der Quadrate aus dem Beispiel "Tabelle der Quadrate". 


Kapitel 5 

EINFACHE PROGRAMM-SCHLEIFEN 


Beispiel: 

(0040) - 03 
(0041) = 06 
Ergebnis: (0042) = 2D 

das heißt 3 2 +6* - 19 + 36 (dezimal) 

-45- 2D 16 

10) Zweierkomplement 

Zweck: Plaziere das Zweier-Komplement des Inhalts des Speicherplatzes 0040 
in den Speicherplatz 0041. Das Zweier-Komplement ist das Einer- 
Komplement plus eins. 

Beispiel: 

(0040) = 3E 
Ergebnis; (0041) - C2 

Die Summe der ursprünglichen Zahl und ihres Zweier Komplements ist null. Da¬ 
her ist das Zweier-Komplement von X gleich 0-X. Welche Lösung (Berechnung 
des Einer-Komplements und Addieren von eins, oder Subtrahieren von null) er¬ 
gibt ein kürzeres und schnelleres Programm? 


Die Programmschleife ist die grundlegende Struktur, die die CPU zur Wieder¬ 
holung einer Folge von Befehlen zwingt. Schleifen besitzen vier Abschnitte: 

1) Der Start- oder Initialisierungs-Abschnitt, der den Anfangswert der Zähler, 
Indizes, Zeiger und andere Variablen einrichtet. 

2) Der Verarbeitungs-Abschnitt, in dem die tatsächliche Daten-Manipulation 
auftritt. Dieser Abschnitt verrichtet die eigentliche Arbeit. 

3) Der Schleifen-Steuerabschnitt, der die Zähler und Indizes für die nächste 
Wiederholung auf den entsprechenden Stand bringt. 

4) Der Abschluß-Abschnitt, der die Ergebnisse analysiert und speichelt. 

Es ist zu beachten, daß der Computer die Abschnitte 1 und 4 nur einmal durch¬ 
läuft, während dies bei den Abschnitten 2 und 3 mehrmals der Fall sein kann. 
Daher hängt die Ausführungszeit der Schleife im wesentlichen von der Ausfüh- 
rungszeit der Abschnitte 2 und 3 ab. Man wird daher trachten, daß die Abschnit¬ 
te 2 und 3 so rasch wie möglich ausgeführt werden. Die Ausführungszeit der 
Abschnitte 1 und 4 sind dagegen zu vernachlässigen. Eine typische Programm¬ 
schleife kann in einem Flußdiagramm gemäß Bild 5-1 dargestellt werden, oder 
es kann die Lage der Verarbeitungs- und Schleifen-Steuer-Abschnitte umge¬ 
kehrt werden, wie in Bild 5-2 gezeigt wird. Der Verarbeitungs-Abschnitt in Bild 
5-1 muß immer wenigstens einmal ausgeführt werden, während der Verarbei¬ 
tungs-Abschnitt in Bild 5-2 auch überhaupt nicht ausgeführt werden muß. Bild 
5-1 scheint natürlicher zu sein, jedoch Bild 5-2 ist häufig effizienter und vermei¬ 
det Probleme, falls keine Daten vorliegen (ein Schreckgespenst für Computer, 
und ein häufiger Grund für verrückte Situationen, wenn ein Computer eine Rech¬ 
nung von 0.00 DM eintreiben soll). 

Die Struktur der Schleife kann zur Verarbeitung ganzer Datenblöcke verwendet 
werden. Um dies auszuführen, muß das Programm das Indexregister nach jeder 
Wiederholung inkrementieren, so daß die effektive Adresse eines indizierten 
Befehls das nächste Element im Datenblock ist. Die nächste Wiederholung wird 
dann die gleichen Operationen an den Daten in der nächsten Speicherstelle 
ausführen. Der Computer kann Blöcke beliebiger Länge (bis zu 256, da die In¬ 
dexregister 8-Bits lang sind) mit dem gleichen Befehlssatz hand haben Die indi¬ 
zierte Adressierung ist der Schlüssel zur Verarbeitung von Datenblöcken mit 
dem 6502, da er uns gestattet, die momentane (oder effektive) Speicher- 
Adresse durch Änderung des Inhalts von Index-Registern zu variieren. Man 
beachte, daß bei den direkten und unmittelbaren Adressier-Verfahren die ver¬ 
wendete Adresse vollständig durch den Befehl bestimmt wird und daher fest 
liegt, wenn der Programmspeicher ein Festwertspeicher ist. 
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Bild 5-1. Flufidiagramm einer Programm schleife 
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Bild 5 2. Eine Programm-Schleife, die null Wiederholungen gestattet 
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BEISPIELE 

Summe von Daten 


Zweck: Berechne die Summe einer Serie von Zahlen. Die 
Länge der Serie ist im Spei cherplatz 0041 enthal¬ 
ten und die Serie beginnt im Speicherplatz 0042. 

Speichere die Summe in den Speicher platz 0040. Nimm an, daß die 
Summe eine 8-Bit-Zahl ist, so daß man Überträge ignorieren kann. 


8-BIT- 

SUMMATION 


Beispiel: 

[0041) = 03 
(0042) = 28 
(0043) = 55 
(0044)= 26 

Ergebnis: (0040)-(0042)+ (0043) + (0044) 

= 28+55 + 26 
=. A3 

Es gibt drei Eingaben für die Summe, da (0041 )-03. 

Flußdiagramm: 



Anmerkung (0042+lndex) ist der Inhalt des Speicherplatzes dessen Adresse die 
Summe von 0042 und des Index ist. Erinnern Sie sich daran, daß 
beim 6502 0042 eine 16-Bit Adresse ist, der Index ist eine 8-Bit- 
Versetzung, und (0042+lndex) ist ein Datenbyte mit 8 Bits. 


SUMD 


LDA 

#0 

TAX 


CLC 


ADC 

$42, X 

INX 


CPX 

$41 

BNE 

SUMD 

STA 

$40 

BRK 



[SUMME = NULL 
;INDEX = NULL 

[ÜBERTRAG NICHT EINSCHLÜSSEN 
;SUMME = SUMME+ DATEN 
[INKREMENTIERE INDEX 
[WURDEN ALLE ELEMENTE SUMMIERT ? 
NEIN, SETZE SUMMIEREN FORT 
;JA, SPEICHERE SUMME 


Objektprogramm 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Flex) 

Befehl 

(Mnempnik) 

0000 

A9 

LDA 

#0 

0001 

00 



0002 

AA 

TAX 


0003 

18 

SU MD CLC 


0004 

75 

ADC 

$42.X 

0005 

42 



0006 

E8 

INX 


0007 

E4 

CPX 

$41 

0008 

41 



0009 

DO 

BNE 

SUMD 

OOOA 

F8 



0008 

85 

STA 

$40 

oooc 

40 



000D 

00 

BRK 



Der Initialisierungsabschnittdes Programmes besteht aus den beiden ersten Be¬ 
fehlen, die die Summe und den Index auf ihre Anfangswerte setzen. Beachten 
Sie. daß TAX den Inhalt des Akkumulators zum Indexregister X transferiert, je¬ 
doch den Akkumulator auf seinem ursprünglichen Wert beläßt. Die Basisadres¬ 
se der Anordnung und der Speicherplatz des Zählers sind innerhalb des Pro¬ 
grammes festgelegt und müssen nicht initialisiert werden. 
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Der Verarbeitungs-Abschnitt besteht aus dem einzelnen Befehl ADC $42,X, der 
den Inhalt der effektiven Adresse (Basisadresse plus Indexregister X) zum Inhalt 
des Akkumulators addiert. Dieser Befehl führt die tatsächliche Arbeit des Pro¬ 
grammes aus. Der CLC-Befehl löscht einfach das Übertrags Flag, so daß es die 
Summation nicht beeinflußt. Beachten Sie, daß jede Wiederholung der Schleife 
eine Addition zum Inhalt einer neuen effektiven Adresse bedeutet, auch 
wenn sich die Befehle ändern. 

Der Schleifen-Steuerabschnitt des Programmes besteht aus dem Befehl INX. 
Dieser Befehl bringt das Indexregister auf den neuesten Stand (um 1), 
so daß die nächste Wiederholung die nächste Zahl zur Summe addiert. Beach¬ 
ten Sie. daß (0041) - X Ihnen sagt, wieviele Wiederholungen noch auszuführen 
sind. 

Der Befehl BNE bewirkt eine Verzweigung, wenn das Nullflag gleich 0 ist. CPX 
setzt das Nulltlag auf 1, wenn das Indexregister X und der Inhalt 
des Speicherplatzes 0040 gleich sind und 0, wenn dies nicht der Fall ist. Die 
Versetzung ist eine Zweierkomplement-Zahl und die Zählung beginnt von dem 
Speicherplatz, der unmittelbar dem BNE-Befehl folgt. In diesem Fall 
geht der erforderliche Sprung vom Speicherplatz OOOB zum Speicherplatz 0003. 
Daher ist die Versetzung: 

0003- 03 
-0008-+F5 
F8 

Wenn das Nullflag 1 ist, führt die CPU den nächsten Befehl in der Sequenz (STA 
$40) aus. Da CPX $41 der letzte Befehl vor BNE war, der das Nullflag beein¬ 
flußte, bewirkt BNE SUMD eine Verzweigung zu SUMD. wenn CPX $41 nicht ein 
Null-Ergebnis erzeugte, 
d.h. 


f SUMD wenn (X)- (0041) * 0 

(PC)- 

l (PC)+2 wenn (X) - (0041) = 0 

Die 2 wird durch den Zweiwort-Befehl BNE bewirkt. Ein einzelner Befehl, der das 
Dekrementieren und den Sprung kombinieren würde, wäre eine sehr nützliche 
Ergänzung zum Befehlssatz des 6502 

Die Reihenfolge, in der die Befehle ausgeführt werden, ist häufig sehr wichtig. 
INX muß nach ADC $42,X kommen, oder die erste zur Summe zu addierende 
Zahl wäre der Inhalt des Speicherplatzes 0043 anstatt des Inhalts des Speicher¬ 
platzes 0042. CPX $41,X muß rechtzeitig von BNE SUMD kommen, da andern¬ 
falls der Nullstatus, der durch CPX erzeugt wird, durch einen an¬ 
deren Befehl geändert werden könnte 


Die meisten Computerschleifen zählen abwärts anstatt aufwärts, so daß das 
Nullflag als eine Austrittsbedingung dienen kann, wodurch sich ein Vergleichs- 
befehi erübrigt. Dieses Verfahren ist etwas ungewohnt, obwohl es gelegentlich 
bei einem Countdown und in einigen anderen Situationen verwendet wird. 
Erinnern Sie sich daran, daß das Nullflag auf 1 gesetzt wird, wenn 
das Ergebnis eines Befehl 0 ist, und auf 0, wenn das Ergebnis nicht 0 war. 


Wir könnten die Schleife leicht so ändern, daß sie rückwärts durch die Anord¬ 
nung arbeitet (siehe das nächste Flußdiagramm). Das folgende Programm ist 
die entsprechend revidierte Version: 


Ouellprogramm: 


SUMD 


LDA 

#0 

LDX 

$41 

CLC 


ACD 

$41,X 

DEX 


BNE 

SUMD 

STA 

$40 

BRK 



SUMME-0 

INDEX - MAXIMALE ZÄHLUNG 
SCHLIESSE ÜBERTRAG NICHT EIN 
SUMME-SUMME + DATEN 
DEKREMENTIERE INDEX 
VERZWEIGE ZURÜCK WENN ALLE ELE 
MENTE NOCH NICHT SUMMIERT SIND 
SPEICHERE SUMME 


Beachten Sie, daß der Additionsbefehl nun ADC $41.X lautet, anstatt 
ADC $42,X. Die Zahl im Indexregister ist um 1 größer als vorher. Natürlich ist 
das Netto-Ergebnis der Subtraktion von 1 von der Basis-Adresse und dem Ad¬ 
dieren von eins zum Indexregister gleich null. Das neu organisierte Objektpro¬ 
gramm lautet: 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) 

0000 

A9 

LDA 

#0 

0001 

00 



0002 

A6 

LDX 

$41 

0003 

41 



0004 

18 

SUMD CLC 


0005 

75 

ADC 

$41.X 

0006 

41 



0007 

CA 

DEX 


0008 

00 

BNE 

SUMD 

0009 

FA 



000A 

85 

STA 

$40 

0008 

40 



OOOC 

00 

BRK 



CPX und CPY sind das gleiche wie CMP, mit Ausnahme, daß der Inhalt des 
Speicherplatzes von einem Indexregister subtrahiert wird, anstatt vom Akkumu¬ 
lator Beachten Sie jedoch, daß CPX und CPY begrenzte Adressiermöglichkei¬ 
ten haben (siehe Tabelle 3 4). 


Bei den meisten Anwendungen sind die geringfügigen Unterschiede in Zeit und 
Speicher zwischen einer Ausführung einer Schleife und einer anderen nicht von 
großer Bedeutung. Sie sollten daher die Lösung wählen, die am deutlichsten 
und leichtesten anzuwenden ist. Wir werden Programm-Entwicklung und Effi¬ 
zienz später in den Kapiteln 1 3 und 15 besprechen. 
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Sie könnten vielleicht wünschen, die Hexadezimalwerte für die relativen Verset¬ 
zungen in den beiden letzten.Programmen zu verifizieren. Der Abschlußtest je¬ 
der Berechnung besteht im Überprüfen des ordnungsgemäßen Ablaufes eines 
Programmes. Wenn, aus welchem Grund auch immer, Sie hexadezimale Be¬ 
rechnungen häufig ausführen müssen, so nehmen wir an, daß Sie 
über einen Rechner (wie dem programmierbaren Rechner von Texas Instru¬ 
ments) oder über eines der zahlreichen Handbücher für diesen Zweck 
verfügen. 

Flußdiagramm: (des reorganisierten Summations-Programmes) 
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16-Bit-Summe von Daten 


Zweck: Berechne die Summe einer Serie von Zahlen Die Länge der Serie befin¬ 
det sich im Speicherplatz 0042 und die Serie selbst beginnt im Spei¬ 
cherplatz 0043. Speichere die Summe in den Speicherplätzen 0040 und 
0041 (die acht niedrigstwertigen Bits in 0040). 

Beispiel: 


Ergebnis: 

Flußdiagramm: 


(0042) =03 
(0043) = C8 
(0044) = FA 
(0045) =96 

Cd+ FA+ 96- 0258,5 
(0040)- 58 
(0041)- 02 
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Objektprogramm: 



LDA 

TAX 

TAY 

#0 

SUMME-NULL 

INDEX - NULL 

MSBS DERSUMME-NULL 

SUMD 

CLC 


SCHLIESSE ÜBERTRAG NICHT EIN 


ADC 

BCC 

$43,X 

COUNT 

SUMME -SUMME+ DATEN 

COUNT 

INY 

INX 

CPX 

;ADDIERE ÜBERTRAG ZU MSBS DER SUM 
ME 

$42 


BNE 

SUMD 

SETZE FORT BIS ALLE ELEMENTE AD- 
DIERT SIND 


STA 

$40 

SPEICHERE LSBS DER SUMME 


STY 

BRK 

$41 

SPEICHERE MSBS DER SUMME 


Objektprogramm: 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 


Befehl 

(Mnemcnik) 

0000 

A9 


LDA 

#0 

0001 

00 




0002 

AA 


TAX 


0003 

AB 


TAY 


0004 

18 

SUMD 

CLC 


0005 

75 


ADC 

$43.X 

0006 

43 




0007 

90 


BCC 

COUNT 

0008 

01 




0009 

C8 


INY 


000A 

E8 

COUNT 

INX 


000B 

E4 


CPX 

$42 

oooc 

42 




000D 

DO 


BNE 

SUMD 

000E 

F5 




OOOF 

85 


STA 

$40 

0010 

40 




0011 

84 


STY 

$41 

0012 

41 




0013 

00 


BBK 



Der Aufbau dieses Programms ist der gleiche wie der Aufbau des vorhergehen 
den. Die höchstwertigen Bits der Summe müssen nun initialisiert und 
gespeichert werden. Der Verarbeitungs-Abschnitt besteht aus vier Befehlen 
(CLC, ADC $43.X, BCC COUNT; und INY), einschließlich eines bedingten 
Sprunges. 

BCC COUNT bewirkt einen Sprung zum Speicherplatz COUNT, wenn Übetrag - 
0. Daher, wenn es keinen Übertrag aus der 8-Bit-Addition gibt, springt das Pro¬ 
gramm über die Anweisung, die die höchstwertigen Bits der Summe inkre- 
mentieren. Die relative Versetzung ist 

000A 

0009 

01 

Die relative Versetzung für BNE SUMD ist 

0004 0004 

--000F +FFF1 
FS 

INY addiert 1 zum Inhalt des Indexregisters X, das hier als zeitweiliges Register 
zum Aufbewahren der Überträge aus der Addition dient. Wir könnten auch einen 
Speicherplatz zum Aufbewahren der Überträge verwenden, da der INC- 
Befehl zum direkten Inkrementieren des Inhaltes eines Speicherplatzes ein¬ 
gesetzt werden kann. 

Sie möchten vielleicht versuchen, dieses Programm neu so anzuordnen, daß es 
den Index abwärts auf null dekrementiert, anstatt ihn zu inkrementieren. Welche 
Version ist kürzer und schneller? 


Relative Verzweigungen sind auf kurze Entfer¬ 
nungen beschränkt (7F 1S oder +127 vorwärts, 

80,6 oder -128 rückwärts vom Ende des Verzwei¬ 
gungsbefehls). Diese Begrenzung ist selten von Bedeutung, da die meisten Pro¬ 
gramm-Verzweigungen kurz sind. 

Wenn Sie jedoch eine bedingte Verzweigung mit einem größeren Bereich benö¬ 
tigen. können Sie immer die Bedingungslogik inveitieren und die Verzweigung 
über einen JMP-Befehl ausführen. Um zum Beispiel zum Speicherplatz FAR zu 
verzweigen, wenn Übeitrag - 0. verwenden Sie die Sequenz 

BCS NEXT 
JMP FAR 

NEXT 


LANGE BEDINGTE 
VERZWEIGUNGEN 


NEXT ist die Adresse, die unmittelbar dem letzten Byte des JMP-Befehls folgt. 
JMP gestattet nur absolute (direkte) und indirekte Adressierung. 
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Quellprogramm: 


Anzahl der negativen Elemente 

Zweck: Bestimme die Anzahl der negativen Elemente (höchstwertiges Bit 1) in 
einem Block. Die Länge des Blocks befindet sich im Speicherplatz 0041 
und der Block selbst beginnt im Speicherplatz 0042. Plaziere die Anzahl 
der negativen Elemente in den Speicherplatz 0040. 


Beispiel: 


(0041)-06 
(0042) - 68 
(0043)- F2 
(0044)-87 
(0045)- 30 
(0046) -59 
(0047) -2A 

Ergebnis- (0040) - 02, da 0043 und 0044 Zahlen mit einem MSB von 1 

enthalten. 


Flußdiagramm: 


N(neg) = Nlneg) ♦ 1 





LDX #0 
LDY #0 

SRNEG LDA $42,X 
BPL CHCNT 
INY 

CHCNT INX 
CPX $41 
BNE SRNEG 

STY $40 
BRK 


;INDEX -NULL 

iANZAHL DER NEGATIVEN = NULL 
;IST DAS NÄCHSTE ELEMENT NEGATIV? 

;JA, ADDIERE 1 ZUR NEGATIVZÄHLUNG 


jSETZE FORT, BIS ALLE ELEMENTE GE- 
; PRÜFT SIND 

BEWAHRE NEGATIVZÄHLUNG AUF 


Objektprogramm: 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 


Befehl 

(Mnemonik) 

0000 

A2 


LDX 

#0 

0001 

00 




0002 

AO 


LDY 

#0 

0003 

00 




0004 

85 

SRNEG 

LDA 

$42.X 

0005 

42 




0006 

10 


BPL 

CHCNT 

0007 

01 




0008 

C8 


INY 


0009 

es 

CHCNT 

INX 


000A 

E4 


CPX 

$41 

000B 

41 




OOOC 

DO 


BNE 

SRNEG 

000D 

F6 




000E 

84 


STY 

$40 

OQOF 

40 




0010 

00 


BRK 



LDA beeinflußt das Negativ-(N)- und Nuil-(Z)-Statusflag. Daher können wir un¬ 
mittelbar prüfen um festzustellen, ob eine Zahl, die geladen wurde, negativ oder 
null ist. 

BPL (Branch-on-Plus) bewirkt eine Verzweigung über die spezifizierte Anzahl 
von Speicherplätzen, wenn das Vorzeichen (oder Negativ)-Bit gleich null ist. Ein 
Vorzeichen-Bit von 0 kann eine positive Zahl anzeigen oder einfach den Wert 
der höchstwertigen Bitposition angeben. Die Interpretation hängt davon ab. was 
die Zahl bedeutet 

Die Versetzung für BPL wird vom ersten Speicherplatz berechnet, der dem 
Zweiwort-Befehl folgt. Hier reicht die Versetzung einfach von 0008 bis 
0009, oder einen Speicherplatz (d.h. der INY-Befehl wird übersprungen, wenn 
das Negativ-Bit null ist). Das Negativ-Bit wird null sein, wenn das 
höchstwertige Bit der Daten, die vom Speicher durch den Befehl LDA $42.X ge¬ 
laden werden, null ist. 

Erinnern wir uns daran, daß Zahlen mit negativen Vorzeichen immer ein höchst¬ 
wertiges Bit (Bit 7) von 1 besitzen. Alle negativen Zahlen sind tat¬ 
sächlich größer (im Sinne einer Betrachtung ohne Vorzeichen) als positive 
Zahlen. 
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Finden des Maximums 


Zweck: Finde das größte Element in einem Datenblock. Die Länge des Blocks 
befindet sich im Speicherplatz 0041 und der Block selbst beginnt im 
Speicherplatz 0042. Speichere das Maximum im Speicherplatz 0040. 
Nimm an. daß die Zahlen im Block 8-Bit-Binärzahlen ohne Vorzei¬ 
chen sind. 

Beispiel: 

(0041). 05 
(0042) =67 
(0043) - 7 9 
(0044) - 15 
(0045)-E3 
(0046) = 72 

Ergebnis: (0040) = E3. d a dies die größte der fünf Zahlen ohne 

Vorzeichen ist. 


Flußdiagramm: 
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Quellprogramm: 



LDX 

EDA 

$41 

#0 

MAXM 

CMP 

$41.X 


BCS 

LDA 

NOCHG 
$41,X 

NOCHG 

DEX 

BNE 

MAXM 


STA 

BRK 

$40 


HOLE ZÄHLUNG 

MAXIMUM = NULL (KLEINSTMÖGLICHER 
WERT) 

IST NÄCHSTES ELEMENT ÜBER MAXI¬ 
MUM? 

JA, BEWAHRE MAXIMUM AUF 
NEIN, ERSETZE MAXIMUM DURCH ELE¬ 
MENT 

SETZE FORT BIS ALLE ELEMENTE GE¬ 
PRÜFT SIND 

BEWAHRE MAXIMUM AUF 
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Objektprogramm: 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 


Befehl 

(Mnemonik) 

0000 

A6 


LDX 

$41 

0001 

41 




0002 

A9 


LDA 

#0 

0003 

00 




0004 

D5 

MAXM 

CMP 

$41 X 

0005 

41 




0006 

BO 


BCS 

NOCHG 

0007 

02 




0008 

B5 


LDA 

$41 X 

0009 

41 




OOOA 

CA 

NOCHG 

DEX 


000B 

DO 


BNE 

MAXM 

000C 

F7 




OOOD 

85 


STA 

$40 

OOOE 

40 




OOOF 

00 


BRK 



Die relative Versetzung für BCS NOCHG ist: 

OOOA 

-0008 

02 

Die relative Versetzung für BNE MAXM ist: 

0004 04 

-OOOD +F3 
F7 

Die ersten zwei Befehle dieses Programmes bilden den Initialisierungs- 
Abschnitt. 

Dieses Programm benützt die Tatsache, daß Null die kleinste 8-Bit-Binärzaht 
ohne Vorzeichen ist. Wenn man das Register, das den Maximalwert 
enthält (in diesem Falle der Akkumulator) aut den kleinstmöglichsten Wert vor 
dem Eintritt in die Schleife setzt, dann wird das Programm den Ak¬ 
kumulator auf einen größeren Wert setzen, außer alle Elemente in der Anord¬ 
nung sind Nullen. 

Das Programm arbeitet ordnungsgemäß, wenn es zwei Elemente gibt, jedoch 
nicht, wenn nur eines oder überhaupt keines vorliegt. Warum? Wie 
könnte man dieses Problem lösen? 


Der Befehl CMP $41 ,X setzt das Übertrags-Flag wie folgt (ELEMENT ist der In¬ 
halt der effektiven Adresse und MAX ist der Inhalt des Akkumulators A): 

Übertrag 0 wenn ELEMENTE > MAX 

Übertrag-1 wenn ELEMENT sS MAX 

Erinnern Sie sich daran, daß der Übertrag ein invertiertes Borgen ist. Wenn 
Übertrag = 1, geht das Programm zur Adresse NOCHG weiter und ändert das 
Maximum nicht Wenn Übertrag = 0, ersetzt das Programm das alle Maximum 
durch das momentane Element durch Ausführung des Befehls LDA $41 ,X, 

Das Programm arbeitet nicht, wenn es sich um Zahlen mit Vorzeichen handelt, 
da negative Zahlen größer als positive erscheinen werden. Dieses Problem ist 
etwas verzwickt, da ein Zweierkomplement-Überlauf das Vorzeichen des Ergeb¬ 
nisses verfälschen könnte. Ein weiteres Problem besteht darin, daß der CMP- 
Befehl das Überlauf-Flag nicht beeinflußt Ein Programm für Zahlen mit Vor¬ 
zeichen müßte daher den SBC-Belehl verwenden und sowohl das Vorzeichen 
wie das Überlauf-Fiag prüfen. Das Übertrags-Fiag müßte auf 1 vor der Subtrak¬ 
tion gesetzt werden (erinnern Sie sich daran, daß der Übertrag ein invertiertes 
Borgen ist und der SBC-Befehl es vor der Subtraktion invertiert) und es wäre 
eine Addition erforderlich, um den ursprünglichen Wert des Maximums wieder 
herzustellen. Beachten Sie, wie bequem es in diesem Beispiel ist, 
daß CMP den Inhalt des Akkumulators nicht wirklich ändert. 
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Quellprogramm: 


Justieren einer gebrochenen Binärzahl 

Zweck: Verschiebe den Inhalt des Speicherplatzes 0040 nach links, bis das 
höchstwertige Bit der Zahl 1 ist. Speichere das Ergebnis in den Spei¬ 
cherplatz 0041 und die Anzahl der erforderlichen Links-Verschiebungen 
in den Speicherplatz 0042. Wenn der Inhalt des Speicherplatzes 0040 
null ist, lösche sowohl 0041 wie 0042. 

Anmerkung: Dieser Vorgang entspricht der Umwandlung einer Zahl in Expcnen- 
tiat-Schreibweise. Zum Beispiel: 

0.0057- 5.7 x 10"3 


Beispiele: 


a. 

(0040) - 22 

Ergebnis: 

(0041) - 88 
(0042) - 02 

b. 

(0040) - 01 

Ergebnis: 

(0041)-80 
(0042)-07 

c. 

(0040)-CB 

Ergebnis: 

(004 1) - CB 
(0042) - 00 

d 

(0040) - 00 

Ergebnis: 

(0041)-00 
(0042) - 00 


Flußdiagramm: 




LDY 

#0 

;ANZAHL DER VERSCHIEBUNGEN 0 


LDA 

$40 

:HOLE DATEN 


BEQ 

DONE 

,DONE, WENN DATEN NULL 

CHKMS 

BMI 

DONE 

:DONE, WENN MSB= 1 


IN Y 


;ADDIERE 1 ZUR ANZAHL DER VERSCHIE- 




; BUNGEN 


ASL 

A 

;SCHIEBE UM 1 BIT NACH LINKS 


JMP 

CHMKS 


DONE 

STA 

$42 

BEWAHRE JUSTIERTE DATEN AUF 


STY 

$42 

BEWAHRE ANZAHL DER VERSCHIEBUNG- 




: GEN AUF 


BRK 




Objektprogramm: 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 


Befehl 

(Mnemcnik) 

0000 

AO 


LDY 

#0 

0001 

00 




0002 

A5 


LDA 

$40 

0003 

40 




0004 

FO 


BEQ 

DONE 

0005 

07 




0006 

30 

CHKMS 

BMI 

DONE 

0007 

05 




0008 

C8 


INY 


0009 

OA 


ASL 

A 

000A 

4C 


JMP 

CHKMS 

oooe 

06 




oooc 

00 




000D 

85 

DONE 

STA 

$41 

OOOE 

41 




000F 

84 


STY 

$42 

0010 

42 




0011 

00 


BRK 
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BMI DONE bewirkt einen Sprung zum Speicherplatz DONE. wenn das Vorzei¬ 
chen-Bit 1 ist. Diese Bedingung kann bedeuten, daß das letzte Ergeb¬ 
nis eine negative Zahl war, oder kann einfach bedeuten, daß ihr höchstwertiges 
Bit 1 war, der Computer liefert nur die Ergebnisse. Der Programmierer muß für 
die Interpretation sorgen 

ASLA verschiebt den Inhalt des Akkumulators um ein Bit nach links und löscht 
das niedrigstwertige Bit. 

JMP ist ein Betehl für einen unbedingten Sprung, der immer einen neuen Wert in 
den Befehlszähler plaziert Er gestattet nur absolute (direkte) oder indirekte 
Adressierung. Die indirekte Adressierung ergibt höhere Flexibilität, da die tat¬ 
sächliche Bestimmungsadresse im RAM gespeichert werden kann. Beachten 
Sie, daß es keine relative Adressierung und keine spezielle Nullseiten-Arten 
gibt. 

Die Adresse im JMP-Betehl wird in zwei aufeinanderfolgenden Speicherplätzen 
aufbewahrt, mit dem niedrigstwertigen Bit zuerst (bei der niedrigeren Adresse). 
Dies ist der Standardweg, in dem der Mikroprozessor 6502 erwartet, Adres¬ 
sen aufzufinden, unabhängig davon, ob sie ein Teil von Befehlen sind oder indi¬ 
rekt verwendet werden. Die gleiche Methode von "oben nach unten" wird beim 
8080, 8085 und Z80 verwendet jedoch die entgegengesetzte Lösung (höchst- 
wertge Bits zuerst) wird beim Mikroprozessor 6800 verwendet. Beachten Sie, 
daß eine Adresse zwei Speicherbytes belegt, obwohl es nur ein einzelnes Da¬ 
tenbyte an dieser Adresse gibt. 

Wir könnten dieses Programm neu organisieren, so daß es den zusätzlichen 
JMP Betehl eliminiert. Eine neu organisierte Version wäre: 


LDY #0 
LDA $40 
BEQ DONE 
CHKMS INY 

ASL A 
BCC CHKMS 
ROR A 

DEY 

DONE STA $41 
STY $42 

BRK 


;ANZAHL DER VERSCHIEBUNGEN = 0 
;HOLE DATEN 

;D0nE, WENN DATEN NULL SIND 
iADDIERE 1 ZUR ANZAHL DER VERSCHIE- 
, BUNGEN 

;VERSCHIEBE UM EIN BIT NACH LINKS 
;SETZE FORT, WENN MSB NICHT EINS IST 
;ANDERNFALLS VERSCHIEBE EINMAL ZU- 
; RÜCK 

.UND IGNORIERE ZUSÄTZLICHE VERSCHIE- 
; BUNG 

;BEWAHRE JUSTIERTE DATEN AUF 
;BEWAHRE ANZAHL DER VERSCHIEBUNG- 
; EN AUF 


Diese Version verschiebt die Daten, bis der Übertrag 1 wird. Es ordnet dann die 
Daten und die Zahl der Verschiebungen um eins rückwärts an, da die letzte Ver¬ 
schiebung nicht wirklich notwendig war. Zeigen Sie, daß diese Version eben¬ 
falls richtig ist. Was sind ihre Vorteile und Nachteile, verglichen mit dem vor¬ 
hergehenden Programm? Sie könnten vielleicht einige andere Anordnungen 
versuchen, um zu sehen, wie sie Ausführungszeit und Speicherbelegung 
verwenden. 
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Nach-indizierte (indirekte) Adressierung 


Wir haben bereits die zusätzliche Flexibilität NACH-INDIZIERTE 

durch die indizierte Adressierung festgestellt Die (INDIREKTE) 

gleichen Befehle können zum Verarbeiten jedes ADRESSIERUNG 

Elementes in einer Anordnung oder Tabelle die- *=- 

nen. Es wird aber auch erhöhte Flexibilität durch die nach-indizierte Adressie¬ 
rung geliefert, bei der der Betehl nur die Adresse auf der Nullseite spe¬ 
zifiziert, die die Basis Adresse der Tabelle oder Anordnung enthält Nun kann 
dasselbe Programm eine Anordnung oder Tabelle handhaben, die irgendwo im 
Speicher liegt. Alles was wir zu tun haben, besteht im Plazieren der Start- 
Adresse in die entsprechenden Speicherplätze aut der Seite null. Beachten Sie, 
daß die Start-Adresse zwei Speicherbytes belegt, mit dem niedrigstwertigen 
Byte zuerst (bei der niedrigeren Adresse) Nach-Indizierung erfordert zusätzli¬ 
che Takt-Zyklen (sechs vergleichen mit vier für die indizierte Nullseiten- 
Adressierung) ermöglicht jedoch gewaltige zusätzliche Flexibilität. Ganze An¬ 
ordnungen müssen nicht mehr bewegt werden, noch sind wiederholte Versio¬ 
nen des gleichen Programmes erforderlich. 

Nach-indizierte (indirekte) Adressierung kann nur mit dem Indexregister Y ver¬ 
wendet werden. Daher sieht das Maximum-Programm mit nach-indizierter 
Adressierung wie folgt aus, wobei angenommen wird, daß die Länge der Anord¬ 
nung im Speicherplatz 0041 und seine Start-Adresse in den Speicherplätzen 
0042 und 0043 liegen. 


Beispiel: 

(00 41) - 0 5 

(0042) - 43 (LSBs der Start-Adresse minus eins) 

(0043) -00 (MSBs der Start-Adresse minus eins) 

(0040) - 67 (erstes Element in der Anordnung) 

(0045) - 7 9 
(0046)- 15 
(0047)- E3 
(0048J-72 

Ergebnis - (40)- E3, da dies das größte der 5 Zahlen ohne Vorzei¬ 

chen ist. 


Quellprogramm: 



LDY 

$41 


LDA 

#0 

MAXM 

CMP 

($42),Y 


BCS 

NOCHG 


LDA 

($42),Y 

NOCHG 

DEY 


BNE 

MAXM 


STA 

BRK 

$40 


HOLE ELEMENT-ZÄHLUNG 
MAXIMUM = NULL (KLEINSTMÖGLICHER 
WERT) 

IST NÄCHSTES ELEMENT ÜBER MAXI¬ 
MUM? 

NEIN. BEWAHRE MAXIMUM AUF 

JA, ERSETZE MAXIMUM DURCH ELEMENT 

SEZTE FORT. BIS ALLE ELEMENTE GE¬ 
PRÜFT 

BEWAHRE MAXIMUM AUF 
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Objektprogramm: 


Vor-indizierte (indirekte) Adressierung 


Speicher Adresse 
(Hex) 

Speicher-Inhalt 

(Hex) 


Belehl 

(Mnemonik) 

0000 

A4 


LDY 

$41 

0001 

41 




0002 

A9 


LDA 

#0 

0003 

00 




0004 

Dl 

MAXM 

CMP 

($42).Y 

0005 

42 




0006 

80 


8CS 

NOCHG 

0007 

02 




0008 

81 


LDA 

($42).Y 

0009 

42 




OOOA 

ee 

NÖCHG 

DEY 


000B 

DO 


BNE 

MAXM 

oooc 

F7 




000D 

B5 


STA 

$40 

000E 

40 




000F 

00 


BFtK 



Die indirekte Adresse (in den Speicherplätzen 0042 und 0043) werden aut die 
gebräuchliche Weise des 6502 gespeichert,mit den niedrigstwertigen Bits zuerst 
(bei der niedrigeren Adresse), 

Wir könnten das gleiche Programm zum Finden des maximalen Elements in 
einer Anordnung von 5 Eingaben verwenden, beginnend im Speicher¬ 
platz 25E1 Alles was wir zu tun haben, besteht im Ändern der indirekten Adres¬ 
se auf 25E0 vor der Ausführung des Programmes, das heißt: 

(0042) - E0 (LSBs der Strat-Adresse minus eins) 

(0043) = 25 (MSBs der Start-Adresse minus eins) 

Wie würden Sie eine Anordnung handhaben, die im Speicherplatz 25E1 beginnt, 
wenn das verwendete Programm gewöhnliche indizierte Adressierung (wie in 
dem früheren Beispiel) verwenden würde? Nehmen Sie an, daß das Pro¬ 
gramm im ROM liegt, so daß Sie die Adressen in den Befehlen nicht ändern 
können. 


Die vor-indizierte Adressierung ergibt Ihnen eine 
andere Art von Flexibilität. Dieses Verfahren ge¬ 
stattet Ihnen die Auswahl einer Adresse aus ei¬ 
ner Tabelle von Adressen, anstatt auf eine be¬ 
stimmte Speicheradresse begrenzt zu sein. 

Zum Beispiel könnten wir anstatt des Speicherplatzes 0041, der die Länge der 
Anordnung in der Maximums Aufgabe enthält, ihn den Index der Adresse ent¬ 
halten lassen, die wiederum die Länge der Anordnung enthält. Die Tabelle der 
Adressen muß irgendwo auf Seite Null legen, vielleicht beginnend beim Spei¬ 
cherplatz 0060, das heißt 


VOR-INDIZIERTE 

(INDIREKTE) 

ADRESSIERUNG 


(0060)-2F) 

(0061) - 00 J 

Adresse, in die 

(0062)-80 1 
(00631-00 > 

Adresse, in die 

(0064) - A51 
(00651-00 > 

Adresse, in der 


der Zähler 0 gespeichert ist 
der Zähler 1 gespeichert ist 
der Zähler 2 gespeichert ist 


Ein Problem besteht darin, daß die Adressen zwei Speicherbytes belegen, so 
daß Sie die Zählerzahl mit zwei multiplizieren müssen, bevor Sie die vor- 
indizierte Adressierung einsetzen. Beachten Sie, daß alle Adressen in 
der Art und Weise des 6502 gespeichert werden, mit den niedrigstwertigen Bits 
zuerst, Vor-indizierte Adressierung ist nicht so nützlich wie nach-indizierte 
Adressierung, ist jedoch gelegentlich sehr handlich. 
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AUFGABEN 

1) Prüfsumme von Daten 

Zweck: Berechne die Prüfsumme einer Serie von Zahlen. Die Länge der Serie 
befindet sich im Speicherplatz 0041 und die Serie selbst beginnt im 
Speicherplatz 0042. Speichere die Prüfsumme im Speicherplatz 0040. 
Die Prüfsumme wird durch Exklusiv-ODERieren aller Zahlen der Serie 
gebildet 

Anmerkung: Derartige Prüfsummen werden häufig bei Lochstreifen- und Kasset- 
ten-Systemen verwendet, um sicherzustellen, daß die Daten ord¬ 
nungsgemäß gelesen wurden. Die berechnete Prüfsumme wird mit 
einer anderen verglichen, die mit den Daten gespeichert ist. 
Wenn die beiden Prüfsummen nicht übereinstimmen, wird das Sy¬ 
stem gewöhnlich entweder dem Operator einen Fehler melden 
oder die Daten automatisch nochmals lesen. 

Beispiel: 

(0041) = 03 
(0042) = 28 
«043) = 55 
(0044) = 26 

Ergebnis: (0040) = (0042) © (0043) © (0044) 

= 28 ©55 ©26 
= 00101000 
$ 01010 101 
01111101 
© 0010011 0 
01011011 
= 5B 


2) Summe von 16-Bit-Daten 

Zweck: Berechne die Summe einer Serie von 16-Bit-Zahlen. Die Länge 
der Serie befindet sich im Speicherplatz 0042 und die Serie 
selbst beginnt im Speicherplatz 0043. Speichere die Summe in 
den Speicherplatz 0040 und 0041 (die acht höchstwertigen Bits in 
0041). Jede 16-Bit-Zahl belegt zwei Speicherplätze, mit den acht 
höchstwertigen Bits in der höheren Adresse. Nimm an, daß die Summe 
in 16 Bits Platz findet. 

Beispiel: 

(0042) - 03 
(0043) - Fl 
(0044) - 28 
(0045) - 1A 
(0046) - 30 
(0047) - 39 
(0048) - 4B 

Ergebnis: 29F1 + 301A + 4B99 - A494 

(0040) - 94 
(0041) - A4 
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3) Anzahl der Nullen, positiven und negativen Zahlen 

Zweck: Bestimme die Anzahl der Nullen, positiven (höchstwertigen Bit null, je¬ 
doch die gesamte zahl keine Nullen) und negativen (höchstwertiges Bit 
1) Elemente in einem Block. Die Länge des Blocks befindet sich im 
Speicherplatz 0043 und der Block selbst beginnt in Speicherplatz 0044. 
Plaziere die Anzahl der negativen Elemente in den Speicherplatz 0040, 
die Anzahl der Null-Elemente in den Speicherplatz 0041, und die Anzahl 
der positiven Elemente in den Speicherplatz 0042. 

Beispiel: 

(0043) - 06 
(0044) = 68 
(0045) - F2 
(0046) = 87 
(0047) - 00 
(0048) - 59 
(0049) = 2A 

Ergebnis: 2 negative, 1 Null und 3 positiv, daher 

(0040) - 02 
(0041) - 01 
(0042) - 03 


4) Finden des Minimums 

Zweck: Finde das kleinste Element in einem Datenblock. Die Länge des Blocks 
befindet sich im Speicherplatz 0041 und der Block selbst beginnt im 
Speicherplatz 0042. Speichere das Minimum in den Speicherplatz 
0040 Nimm an, daß die Zahlen in dem Block 8-Bit-Binärzahlen ohne 
Vorzeichen sind. 

Beispiel: 

(0041) = 05 
(0042) = 67 
(0043) - 79 
(0044) - 15 

(0045) - E3 
(0046) - 72 

Ergebnis: (0040) = 15, da dies die kleinste der 

fünf Zahlen ohne Vorzeichen ist. 

5) Zähle 1-Bits 

Zweck: Bestimme, wieviele Bits im Speicherplatz 0040 gleich Eins sind und pla¬ 
ziere das Ergebnis in den Speicherplatz 0041. 

Beispiel: 

(0040) - 3B - 00111011 

Ergebnis: (0041) = 05 
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Kapitel 6 

ZEICHENCODIERTE DATEN 


Mikroprozessoren verarbeiten häutig zeichencodierte Daten. Nicht nur Tasta¬ 
turen, Fernschreiber, Kommunikationsgeräte, Anzeigen und Computer- 
Terminals erwarten oder liefern zeichencodierte Daten. Auch zahlreiche In¬ 
strumente, Test-Systeme und Steuergeräte benötigen Daten in dieser Form. 
Der am häufigsten verwendete Code ist ASCII. Baudot und EBCDIC findet man 
seltener. Wir wollen annehmen, daß alle unsere zeichencodierten Daten in 
Form von 7-Bit-ASCII vorliegen, wobei das höchstwertige Bit 0 ist (siehe 
Tabelle 6-1). 

Einige Grundlagen zur Handhabung von ASCII- 
cod ierten Daten sind: 


1) Die Codes für die Zahlen und Buchstaben bilden geordnete Unter¬ 
sequenzen. Die Codes für Dezimalzahlen sind 30,* bis 39, 6 , so daß man eine 
Umwandlung zwischen dezimal und ASCII mit einem einfachen additiven 
Faktor durchführen kann. Die Codes für die Großbuchstaben sind 41 1S bis 
5A, Sl so daß man eine alphabetische Anordnung durch Sortieren der Daten 
mit steigender numerischer Ordnung erhalten kann 

2) Der Computer macht keinen Unterschied zwischen druckenden und nicht 
druckenden Zeichen. Diese Unterscheidung wird nur durch die E/A-Bau- 
steine getroffen. 

3) Ein ASCII-Baustein wird nur ASCII-Daten verarbeiten. Um eine 7 auf einem 
ASClI-Drucker auszudrucken, muß der Mikroprozessor 37, 6 zum Drucker 
senden. 07, 6 ist das Zeichen für "Klingel". Ähnlich wird der Mikroprozessor 
das Zeichen 9 von einer ASCII-Tastatur als 39, s empfangen. 09, 6 ist das 
Tabulator-Zeichen. 

4) Einige ASCII-Bausteine verwenden nicht den vollen Zeichensatz. Beispiels¬ 
weise können Steuerzeichen und Kleinbuchstaben ignoriert oder als Zwi¬ 
schenräume oder Fragezeichen gedruckt werden 

5) Einige häufig verwendete ASCII-Zeichen sind: 

0A 16 = line feed (LF - Zeilenvorschub) 

0D,s - camiage return (CR = Wagenrücklauf) 

20, 6 - space (Zwischenraum) 

3F,s -? (Fragezeichen) 

7F,6 - delete character (Löschzeichen) 

6) Jedes ASCII-Zeichen belegt 8 Bits. Dies gestattet einen größeren Zeichen¬ 
satz, ist jedoch verschwenderisch, wenn die Daten auf einen kleineren Teil¬ 
satz begrenzt sind, wie etwa die Dezimalzahlen. Ein 8-Bit-Byte kann bei¬ 
spielsweise nur eine ASCIl-codieite Dezimalzahl enthalten, dagegen jedoch 
zwei BCD-codierten Ziffern. 


HANDHABUNG 
VON DATEN 
IN ASCII 
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a o 


BEISPIELE 

Länge einer Zeichenreihe 


Zweck: Bestimme die Länge einer Reihe (String oder Kette) von ASCII- 
Zeichen (7 Bits mit einem höchstwertigen Bit 0). Die Reihe beginnt 
im Speicherplatz 0041. Das Ende der Reihe wird durch ein Wagen¬ 
rücklauf-Zeichen ('CR\ 0D, S ) markiert Plaziere die Länge der Reihe 
(ausschließlich des Wagenrücklaufs) im Speicherplatz 0040. 

Beispiele: 


a. (0041 )_0D 

Ergebnis. (0040) - 00 da das erste Zeichen ein Wagen- 

rücklaul ist. 

b - (0041) = 52 'R' 

(0042) =41 'A' 

(0043)= 54 T 
(0044) = 48 'H' 

(0045)= 45 ’E' 

(00461=52 ’R‘ 

(0047)= 0D CR 

Ergebnis: (0040) =06 


Flußdiagramm: 
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Quellprogramm: 



LDX 

#0 

länge der reihe - null 


LDA 

# $0D 

;HOLE WAGENRÜCKLAUF FÜR VERGLEICH 

CHKCR 

CMP 

$41 .X 

IST DAS ZEICHEN EIN WAGENRÜCKLAUF? 


BEQ 

DONE 

;JA. DONE 


INX 


;NEIN, ADDIERE 1 ZUR REIHENLANGE 


JMP 

CHKCR 


DONE 

STX 

$40 

;BEWAHRE REIHENLANGE AUF 


BRK 




Objektprogramm: 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 


Befehl 

(Mnemonik) 

0000 

A2 


LDX 

#0 

0001 

00 




0002 

A9 


LDA 

#$0D 

0003 

0D 




0004 

D5 

CHKCR 

CMP 

$41 X 

0005 

41 




0006 

FO 


BEO 

DONE 

0007 

04 




000B 

EB 


INX 


0009 

4C 


JMP 

CHKCR 

000A 

04 




000B 

00 




oooc 

86 

DONE 

STX 

$40 

000D 

40 




000E 

00 


BRK 



Der Wagenrücklauf (CR) ist nur ein weiteres ASCII Zeichen (ÖD,«), soweit es den 
Computer betrifft Oie Tatsache, daß der Ausgangs-Baustein den Wagenrücklauf 
als Steuerzeichen anstatt als Druckzeichen behandelt, beeinflußt den Computer 
nicht. 


Beachten Sie, daß man durch Neuanordnung der Logik und Änderung der 
Anfangsbedingungen dieses Programm verkürzen und die Ausführungszeit 
verringern kann. Wenn wir das Flußdtagramm so anordnen, daß das Pro¬ 
gramm den Zähler und den Zeiger inkrementiert, bevor es nach dem Wagen¬ 
rücklauf Ausschau halt, ist nur eijn Sprungbefehl anstelle von zwei erforder¬ 
lich. Das neue Flußdiagramm und das Programm sieht dann folgendermaßen 
aus: 


Flußdiagramm: 



Der Vergleichs-Befehl CMP setzt die Flags, als ob eine Subtraktion ausgeführt 
worden wäre, läßt jedoch das Zeichen für den Wagenrücklauf für spätere Ver¬ 
gleiche im Akkumulator, Das Z-Flag wird wie folgt beeinflußt: 

Z - 1 wenn das Zeichen in der Reihe ein Wagenrücklauf ist 
Z - 0 wenn es kein Wagenrücklauf ist 

Der Befehl INX addiert 1 zum Reihenlängen-Zähler im Index-Register X. LDX#0 
initialisiert diesen Zähler auf 0, bevor die Schleife beginnt. Erinnern Sie sich da¬ 
ran, Variable zu initialisieren, bevor sie in einer Schleife verwendet werden. 

Diese Schleife begrenzt nicht, da der Zahler nicht auf null dekrementiert wird 
oder einen Maximalwert erreicht. Der Computer wird einlach mit der Prüfung 
von Zeichen fortfahren, bis er einen Wagenrücklauf findet Man muß eine 
maximale Zahlung in eine Schleife wie dieser plazieren, um Probleme mit 
fehlerhaften Reihen, die keinen Wagenrücklauf enthalten zu vermeiden. Was 
würde geschehen, wenn das Programmbeispiel mit einer derartigen Reihe 
verwendet würde? 


Quellprogramm: 


LDX *$FF 
LDA #$0D 

CHKCR INX 

CMP $41 ,X 
BNE CHKCR 
STX $40 
BRK 


;LÄNGE DER REIHE—1 

;HOLE ASCII-WAGENRÜCKLAUF FÜR VER- 

; GLEICH 

;ADDIERE 1 ZUR REIHENLÄNGE 

;IST DAS ZEICHEN EIN WAGENRÜCKLAUF? 

;NEIN, P RUFE NÄCHSTES ZEICHEN 

JA. BEWAHREZEICHENLANGE AUF 


Diese Version ist nicht nur kürzer und schneller, sondern sie beinhaltet 
auch keine absoluten Ziel-Adressen. Daher kann sie leicht überall in den 
Speicher plazierl werden. Die frühere Version enthält einen JMP-Befehl 
mit einer spezifischen absoluten Adresse, während diese Version nur 
Verzweigungsbefehle mit relativen Adressen besitzt. 
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Objektprogramm: 


Speicher Adresse 
(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnempnik) 

0000 

A2 

LDX 

#$FF 

0001 

FF 



0002 

A9 

lda 

#$0D 

0003 

OD 



0004 

E8 

CHKCR inx 


0005 

D5 

CMP 

$41.X 

0006 

41 



0007 

DO 

BNE 

CHKCR 

0008 

F0 



0009 

86 

STX 

$40 

000A 

40 



0000 

00 

BRK 
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Suchen des ersten Nicht-Zwischenraum-Zeichens 


Zweck: Absuchen einer Reihe von ASCII-Zeichen (7 Bits mit höchstwertigem Bit 
0) nach einem Nicht-Zwischenraum-Zeichen. Die Reihe beginnt im Spei¬ 
cherplatz 0042. Plaziere den Index des ersten Nicht-Zwischenraum- 
Zeichens in den Speicherplatz 0040. Ein Zwischenraum-Zeichen ist 20, e 
in ASCII. 

Beispiel: 

a (0042) - 37 ASCII 

Ergebnis (0040) - 00 da der Speicherplatz 0042 ein Nicht- 

Ergebnis - Zwischenraum Zeichen enthält. 

b. (0042) - 0 SP 

(0043) - 20 SP 

(0044) - 20 SP 

(0045) - 46 F 

(0046) - 20 SP 

Ergebnis; (0040) - 03 da die vorausgehenden Speicherplätze 

lauter Zwischenräume enthalten. 


Rußdiagramm: 
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Quellprogramm: 



LDX 

#0 

BEGINNE MIT INDEX-NULL 


LDA 

#' 

HOLE ASCII-ZWISCHEN RAUM FÜR VER¬ 
GLEICH 

CHBLK 

CMP 

$42,X 

IST DAS ZEICHEN EIN ASCII- 
ZWISCHENRAUM? 


BNE 

INX 

JMP 

DONE 

CHBLK 

NEIN, DONE 

JA, PRÜFE NÄCHSTES ZEICHEN 

DONE 

STX 

BRK 

$40 

BEWAHRE INDEX DES ERSTEN NICHT- 
ZWISCHENRAUM-ZEICHENS AUF 


Objektprogramm: Beachten Sie die Verwendung eines Apostrophs (') vor 
einem ASCII-Zeichen 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 


Befehl 

(Mnemonik) 

0000 

A2 


LDX 

#0 

0001 

00 




0002 

A9 


LDA 

#' 

0003 

20 




0004 

D5 

CHBLK 

CMP 

$42 X 

0005 

42 




0006 

DO 


BNE 

DONE 

0007 

04 




0008 

E8 


INX 


0009 

4C 


JMP 

CHBLK 

000A 

04 




0008 

00 




oooc 

86 

OONE 

STX 

$40 

0000 

40 




000E 

00 


BRK 



Das Aufsuchen von Zwischenräumen in Reihen ist eine häufig vorkommende 
Aufgabe. Zwischenräume werden oft aus Reihen entfernt, wenn sie einlach nur 
zur Erhöhung der Lesbarkeit oder für spezielle Formate verwendet werden. Es 
ist eine offensichlliche Verschwendung, Extra-Zwischenräume zu speichern und 
deren Beginn und Ende zu übertragen, speziell wenn man für die Übertragungs¬ 
zeit und für den Speicherraum zahlen muß. Daten- und Programmeingabe ist je¬ 
doch wesentlich einfacher, wenn Extra-Zwischenräume toleriert werden. Mikro¬ 
computer werden häufig in Situationen ähnlich dieser verwendet, um die Form 
von Daten zwischen von Menschen leicht lesbarer Form und vom Computer und 
Übertragungsleitungen wirtschaftlich zu handhabenden Formen umzuwandeln. 

Wiederum könnten wir, wenn wir die Anfangsbedingungen so ändern, daß der 
Schleifen-Steuerabschnitt dem Verarbeitungsabschnitt vorausgeht, die Anzahl 
der Bytes im Programm und die Ausführungszeit der Schleife verringern Das 
neu angeordnete Flußdiagramm sieht folgendermaßen aus: 


Flußdiagramm: 


Quellprogramm: 



LDX #$FF ;STARTE MIT INDEX = -1 

EDA #' ;HOLE ASCII-ZWISCHENRAUM FÜR VER- 

: GLEICH 

CHBLK INX JNKREMENTIERE INDEX 

CMP $42.X ;lSTZEtCHEN EIN ASCII-ZWISCHENRAUM? 

BEO CHBLK ;JA, PRÜFE NÄCHSTES ZEICHEN 

STX $40 ;NEIN, BEWAHRE INDEX DES ERSTEN 

; NICHT-ZWISCHENRAUM-ZEICHENS AUF 

BRK 

Objektprogramm; 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) 

0000 

A2 

LDX 

ASfF 

0001 

FF 



0002 

A9 

LDA 

#' 

0003 

20 



0004 

ES 

CHBLK INX 


0005 

D6 

CMP 

$42 X 

0006 

42 



0007 

F0 

BEQ 

CHBLK 

0008 

FB 



0009 

86 

STX 

$40 

000A 

40 



0006 

00 

BRK 
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Ersetzen führender Nullen durch Zwischenräume 

Zweck: Änderung einer Reihe von ASCII-Dezimalzeichen durch Ersetzen aller 
führender Nullen durch Zwischenräume. Die Reihe beginnt im Speicher¬ 
platz 0041. Nimm an, daß sie zur Gänze aus ASCII-codierten Dezimal¬ 
zahlen besteht. Die Länge der Reihe befindet sich im Speicher¬ 
platz 0040 

Beispiele: 

a (0040) -02 

(0041)-36 ASCII 6 

Das Programm läßt die Reihe unverändert, da die führende Ziffer nicht Null ist. 

b (0040)-08 

(00411-30 ASCII 0 
(0042)-30 ASCII 0 
(0043)-38 ASCII 8 

Ergebnis: (0041) -20 SP 

(0042)- 20 SP 

Die beiden führenden ASCII-Nullen wurden durch ASCII-Zwischenräume ersetzt. 


Flußdiagramm: 
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Quellprogramm: 



LDX 

#0 

.INDEX NULL FÜR START 


LDY 

#' 

;HOLE ASCII-Z WISCH EN RUM FÜR ERSATZ 


LDA 

#'0 

HOLE ASCII-NULL FÜR VERGLEICH 

CHKZ 

CMP 

$41.X 

;IST FÜHRENDE ZIFFER NULL 


BNE 

DONE 

;NEIN, BEENDE AUSTAUSCH VORGANG 


STA 

$41,X 

ilSTFÜHRENDE ZIFFER NULL? 


INX 




CPX 

$40 



BNE 

CHKZ 

;PRÜFE NÄCHSTE ZIFFER FALLS 




; VORHANDEN 

DONE 

BRK 




Ein Apostroph vor einem Zeichen zeigt an, daß der Operand ein ASCII-Code ist. 

Objektprogramm: 



Man wird häufig dezimale Reihen aufbereiten wollen, bevor sie gedruckt oder 
dargestellt werden, um ihr Aussehen zu verbessern. Häufig vorkommende Auf¬ 
bereitungs-Aufgaben beinhalten das Eliminieren von führenden Nullen, Überprü¬ 
fung von Zahlen. Addieren von Vorzeichen oder anderer Identifizierungsmarken 
und Abrundungen. Offensichtlich können gedruckte Zahlen wie 0006 oder 
$27 34382 verwirrend und ermüdend sein 

Hier besitzt die Schleife zwei Ausgänge, einen wenn der Prozessor eine Ziffer 
findet, die nicht Null ist, und den anderen, wenn er die gesamte Reihe überprüft 
hat 
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Der Befehl STY $41 ,X plaziert ein ASCIt-Zwischenraumzeichen (20ie) in ein 
Speicherbyte, das vorher eine ASCII-Null enthielt. Beachten Sie. daß STY nur 
über eine begrenzte Anzahl von Adressier-Aiten verfugt (siehe Tabelle 3-4). Es 
gibt keine indizieilen Adressier-Arten mit dem Register Y. keine Vor Indizierung 
und keine absolute Indizierung. Die einzige indizierte Adressier-Art ist die mit 
der Nullseite zusammen mit Indexregister X 

Es wird angenommen, daß alle Ziffern in einer Reihe in ASCII vorliegen, Das 
heißt, die Ziffern sind 30 16 bis 39, 6 , anstatt der gewöhnlichen Dezimalzahlen 0 
bis 9. Die Umwandlung von dezimal in ASCII besteht einfach in der Addition von 
30,8 zur Dezimalzitfer. 

Sie können ein einzelnes ASCtl-Zeichen in ein Assemblersprachen Programm 
des 6502 plazieren, indem Sie einen Apostroph (') voran stellen. Sie können 
eine Reihe von ASCII-Zeichen in den Programmspeicher plazieren, indem Sie 
die Pseudo-Operation TEXT (Speichere ASCII-Text) mit dem 6502-Assembler 
verwenden. Ein Begrenzer-Zeichen (gewöhnlich /) muß vor und nach dem Text 
stehen. Die gebräuchlichste Form ist: 

Operations- 

Marke Code Operand 
EMSG TEXT /ERROR/ 

Sie müssen sehr sorgfältig Vorgehen, wenn Austast-Nullen vorliegen, und eine 
Null lassen, im Falle alle Ziffern null sind. Wie würden Sie dies machen? 

Beachten Sie, daß jede ASClI-Stelle acht Bits benötigt, verglichen mit vier für 
eine BCD-Stelle. Deshalb ist ASCII ein aufwendiges Format, wenn man numeri¬ 
sche Daten speichert oder überträgt. 


Addition gerader Parität zu ASCII-Zeichen 

Zweck: Addiere gerade Parität zu einer Reihe von 7-Bit-ASCII-Zeichen. Die 
Länge der Reihe befindet sich im Speicherplatz 0040. und die Reihe 
selbst beginnt in Speicherplatz 0041. Plaziere gerade Parität in das 
höchstweitige Bit jedes Zeichens, indem das höchstwertige Bit auf 1 
gesetzt wird, wenn dies für eine Gesamtzahl von 1 - Bits im Wort eine 
gerade Zahl ergibt. 

Beispiel: 

(0040) - 06 
(0041) - 31 
(0042) - 32 
(0043) - 33 
(0044) - 34 
(0045) - 35 
(0046) - 36 

Ergebnis: (0041) - Bl 

(0042) - B2 
(0043) - 33 
(0044) - B4 
(0045) - 35 
(0046) - 36 


Flußdiagramm: 
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Quetlprogramm: 



LDX 

$40 

INDEX - MAXIMALE ZÄHLUNG 

GTDATA 

LDY 

#0 

BIT-ZÄHLUNG NULL FÜR DATEN 


LDA 

$40,X 

HOLE DATEN VOM BLOCK 

CHBIT 

BPL 

CHKZ 

SIND NÄCHSTE DATEN BIT 1? 


INY 


JA. ADDIERE 1 ZUR BIT ZÄHLUNG 

CHKZ 

ASL 

A 

PRÜFE NÄCHSTE BITPOSITION 


BNE 

CHBIT 

BIS ALLE BITS NULL SIND 


TYA 




LSR 

A ;HATTEN DIE DATEN EINE GERADE ANZAHL 




VON 1-BITS'? 


BCC 

NEXTE 



LDA 

$40.X ;NEIN. SETZE PARITÄTSBIT 


ORA 

#%10000000 



STA 

$40,X 


NEXTE 

DEX 




BNE 

GTDATA 

MACHE FÜR GESAMTEN DATENBLOCK 




WEITER 


BRK 




Objektprogramm: 


Speicher Adresse Speicher-Inhalt Befehl 

_(Hex)_(Hex)_(Mnemonik) 


0000 

A6 

LDX 

$40 

0001 

40 



0002 

AO 

GTDATA LDY 

#0 

0003 

00 



0004 

B5 

LDA 

$40X 

0005 

40 



0006 

10 

CHBIT BPL 

CHKZ 

0007 

01 



0008 

C8 

INY 


0009 

OA 

CHKZ ASL 

A 

000A 

DO 

8NE 

CHBIT 

0008 

FA 



OOOC 

98 

TYA 


000D 

4A 

LSR 

A 

OOOE 

90 

BCC 

NEXTE 

000F 

06 



0010 

B5 

LDA 

$40.X 

0011 

40 



0012 

09 

ORA 

#%10000000 

0013 

80 



0014 

95 

STA 

$40 X 

0015 

40 



0016 

CA 

NEXTE DEX 


0017 

DO 

BNE 

GTDATA 

0018 

E9 



0019 

00 

BRK 



Die Parität wird häufig zu ASCII-Zeichen addiert, bevor sie auf verrauschten 
Kommunikationsleitungen übertragen werden, um eine einfache Fehlerprüf- 
Moglichkeit zu liefern. Die Pantät stellt alle Einzefbit-Fehler fest, erlaubt jedoch 
keine Fehlerkorrektur. Das heißt, man weiß, daß ein Fehler aufgetreten ist, wenn 
die Parität falsch ist, man kann jedoch nicht angeben, welches Bit verändert 
wurde. Der Empfänger kann nur eine neuerliche Sendung anfordern 

Das Verfahren zur Berechnung der Parität besteht im Zählen der 1-Bits im 
Datenwort Wenn diese Zahl ungerade ist, wird das MSB des Datenwortes auf 1 
gesetzt, um die Parität gerade zu machen. 

ASL löscht das niedrigstwertige Bit der zu verschiebende Zahl. Deshalb wird 
das Ergebnis einer Fleihe von ASL-Befehlen möglicherweise null sein, unab¬ 
hängig vom ursprünglichen Wert der Daten (versuchen Sie es!) Der Bit- 
zahlungs Abschnitt des Programmbeispieles benötigt nicht nur keinen Zähler, 
sondern stoppt auch das Prüfen der Daten, sobald alle verbleibenden Bits Nul¬ 
len sind. Dieses Verfahren spart in zahlreichen Fällen Ausführungszeit. 

Das MSB der Daten wird auf 1 gesetzt, indem es logisch mit einem Muster 
ODERiert wird, das eine 1 in seinem höchstwertigen Bit und sonst Nullen besitzt. 
Das logische ODERieren eines Bits mit 1 erzeugt ein Ergebnis von 1 , unab¬ 
hängig vom ursprünglichen Wert, während das logische ODERieren eines Bits 
mit 0 den ursprünglichen Wert nicht ändert. 
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Übereinstimmung von Bitmustern 

Zweck: Vergleiche zwei Reihen von ASClI-Zeichen, um feslzustellen, ob sie 
gleich sind. Die Länge der Reihen befindet sich im Speicherplatz 0041. 
Eine Reihe beginnt im Speicherplatz 0042 und die andere im Speicher¬ 
platz 0052. Wenn die beiden Reihen übereinstimmen, lösche Speicher¬ 
platz 0040. Andernfalls setze Speicherplatz 0040 auf FF 16 (alles 
Einsen). 

Beispiele: 

a (0041) - 03 

(0042) - 43 'C’ 

(0043) - 41 A- 
(0044) - 54 T 
(0052) - 43 'C' 

(0053) - 41 'A' 

(0054) - 54 T 

Ergebnis: (0040) - 00 da die beiden Reihen gleich sind. 

b. (0041) - 03 

(0042) - 52 R' 

(0043) - 41 ’A' 

(0044) - 54 ’T 

(0052) - 43 ’C’ 

(0053) - 41 'A' 

(0054) - 54 T 

Ergebnis: (0040) - FF da sich die ersten Zeichen in der Reihe unter¬ 

scheiden 

Anmerkung: Der Vorgang für das Suchen nach Übereinstimmung endet, sobald 
die CPU einen Unterschied findet. Der Rest der Reihen muß nicht 
überprüft werden 
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Flußdiagramm: 
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Quellprogramm: 



LDX 

#0 


LDY 

#$FF 

CHCAR 

LDA 

$42,X 


CMP 

$52,X 


BNE 

DONE 


INX 



CPX 

$41 


BNE 

CHCAR 


LDY 

#0 

DONE 

STY 

$40 


BRK 



STARTE MIT ERSTEM ELEMENT IN DEN- 
REIHEN 

MARKIERER FÜR KEINE ÜBEREIN¬ 
STIMMUNG 

HOLE ZEICHEN VON REIHE 1 
GIBT ES EINE ÜBEREINSTIMMUNG MIT 
REIHE 2? 

NEIN. DONE 


PRÜFE NÄCHSTES PAAR. WENN NOCH 
VORHANDEN 

WENN KEINES VORHANDEN, MARKIERE 
ÜBEREINSTIMMUNG 
BEWAHRE ÜBEREINSTIMMUNGS 
; MARKIERUNG AUF 


Das Indexregister X wird zum Zugriff auf beide Reihen verwendet, nur die 
Basis-Adressen sind verschieden Dieses Verfahren gestattet uns, die Reihen 
überall im Speicher zu plazieren, obwohl wir absolute indizierte Adressierung 
verwenden müßten, wenn die Reihen nicht auf der Nullseite liegen. Wir könnten 
auch die nach-indizierte Adressier-Art (mit Indexregister Y) verwenden, wenn 
wir zwei verschiedene Basis-Adressen irgendwo auf Seite Null gespeichert 
hätten 

Der Befehl CMP S52.X vergleicht den Akkumulator mit dem Inhalt des indizier¬ 
ten Speicherplatzes. Wir könnten den Befehl LDY # 0 durch INY ersetzen. Wes¬ 
halb? Vergleichen Sie die Zeit und die Speicheranforderungen der beiden 
Lösungen Welche Version würden Sie für deutlicher halten? Dieser Austausch 
würde Ihnen auch gestatten, einen Speicherplatz für den Markierer zu verwen¬ 
den. anstatt eines Registers (weshalb?). 


Objektprogramm: 


Speicher-Adresse Speicher-Inhalt Befehl 

(Hex) (Hex) (Mnemonik) 


0000 

A2 

LDX 

#0 

0001 

00 



0002 

AO 

LDY 

#$FF 

0003 

FF 



0004 

B5 

CHCAR LDA 

$42,X 

0005 

42 



0006 

D5 

CMP 

$52 X 

0007 

52 



0008 

DO 

BNE 

DONE 

0009 

07 



000A 

E8 

INX 


0006 

E4 

CPX 

$41 

OOOC 

41 



000D 

DO 

BNE 

CHCAR 

000E 

F5 



000F 

AO 

LDY 

#0 

0010 

00 



0011 

84 

DONE STY 

$40 

0012 

40 



0013 

00 

BRK 



Die Feststellung der Übereinstimmung von Reihen aus ASCII-Zeichen ist ein we¬ 
sentlicher Teil für das Erkennen von Namen und Kommandos, Identifizierung 
von Vanablen oder Operationscodes in Assemblern und Kompilierern, Finden 
von Dateien und zahlreicher anderer Aufgaben 
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AUFGABEN 

1) Länge einer Fernschreib-Nachricht 

Zweck: Bestimme die Länge einer ASClI-Nachricht. Alle Zeichen sind 7-Bit- 
ASCII mit MSB - 0. Die Reihe von Zeichen, in der die Nachricht einge¬ 
bettet ist, beginnt im Speicherplatz 0041, Die Nachricht selbst beginnt 
mit einem ASClI-STX-Zeichen (02,*) und endet mit ETX (03, G ). Plaziere 
die Länge der Nachricht (die Anzahl der Zeichen zwischen dem STX 
und ETX, jedoch ausschließlich der beiden) in den Speicherplatz 0040. 

Beispiel: 

(0041) - 40 
(0042) - 02 STX 
(0043) - 47 'G' 

(0044) - 4F 'O' 

(0054) . 03 ETX 

Ergebnis: (0040) - 02, da es zwei gleiche Zeichen zwischen dem 

STX im Speicherplatz 0042 und ETX im 
Speicherplatz 0045 gibt 


2) Suchen des letzten Nicht-Zwischenraum-Zeichens 

Zweck: Absuchen einer Reihe von ASClI-Zeichen nach dem letzten Nichl- 
Zwischenraum-Zeichen, Die Reihe beginnt im Speicherplatz 0042 und 
endet mit einem Wagenrücklauf-Zeichen (0D, e ). Plaziere die Adresse 
des letzten Nicht-Zwischenraum-Zeichens in den Speicherplatz 0040, 

Beispiele: 

a. (0042) - 37 ASCII 7 

(0043) - 0D CR CR 

Ergebnis: (0040) - 00. da das letzte (und einzige) Nicht-Zwischen- 

raum-Zeichen im Speicherplatz 0042 liegt. 

b. (0042) - 41 'A 1 

(0043) - 20 SP 
(0044) - 48 ’H’ 

(0045) - 41 'A' 

(0046) - 54 T 
(0047) - 20 SP 

(0048) - 20 SP 
(0049) - 0D CR 

Ergebnis (0040) - 04 
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3) Abrunden von dezimalen Reihen in ganzzahlige Form 

Zweck: Aufbereiten einer Reihe von ASCII-Dezimalzeichen, indem alle Ziffern 
rechts vom Dezimalpunkt durch ASCII-Zwischenräume (20,,) ersetzt 
werden. Die Reihe beginnt im Speicherplatz 0041, und es wird ange¬ 
nommen, daß sie zur Gänze aus ASCII-codierten Dezimalziffern sowie 
einem möglichen Dezimalpunkt (2E 1S ) bestehen. Die Länge der Reihe 
befindet sich im Speicherplatz 0040. Wenn kein Dezimalpunkt in der 
Reihe auflritt, so kann angenommen werden, daß der Dezimalpunkt 
ganz am rechten Ende iiegt. 

B eispiel: 

a. (0040) - 04 

(0041) = 37 ASQ17 
(0042) = 2E ASCII 
(0043) = 38 ASCII 8 
(0044) - 31 ASCII 1 

Ergebnis: (0041) - 37 ASCII 7 

(0042) - 2E ASCII 
(0043) = 20 SP 
(0044) = 20 SP 

b, (0040) - 03 

(0041) = 26 ASCII 6 
(00 4 2) - 37 ASCII 7 

(0043) - ASCII 1 

Ergebnis: Unverändeit, da die Zahl mit 671 angenommen wurde 


4) Prüfen auf gerade Parität in ASCII-Zeichen 

Zweck: Prüfen auf gerade Parität in einer Reihe von ASCII-Zeichen Die 
Länge der Reihe liegt im Speicherplatz 0041 und die Reihe selbst 
beginnt im Speicherplatz 0042. Wenn die Parität korrekt ist. lösche 
Speicherplatz 0040 Andernfalls plaziere FF,, (alles Einsen) in den 
Speicherplatz 0040. 

Beispiele: 

a. (0041) - 03 

(0042) - Bl 
(0043) - B2 
(0044) - 33 

Ergebnis (0040) = 00. da alle Zeichen gerade Parität haben, 

b- (0041) - 03 

(0042) - Bl 
(0043) = B6 
(0044) - 33 

Ergebnis (0040) - FF, da die Zeichen im Speicherplatz 0043 nicht 

gerade Parität besitzen. 
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5) Vergleich von Reihen 

Zweck: Vergleiche zwei Reihen von ASCII-Zeichen, um feslzuslellen, welche 
größer isl (das heißt welche der anderen in "alphabetischer" Reihen¬ 
folge folgt). Die Länge der Reihen befindet sich im Speicherplatz 0041. 
Eine Reihe beginnt im Speicherplatz 0042 und die andere im Speicher¬ 
platz 0052. Wenn die Reihe, die im Speicherplatz 0042 beginnt, größer 
oder gleich wie die andere Reihe ist, lösche Speicherplatz 0040. 
Andernfalls setze Speicherplatz 0040 auf FF, 6 (alles Einsen). 


Beispiele: 


a. 

(0041) 

- 

03 


(0042) 

- 

43 ’C' 


(0043) 

- 

41 ’A' 


(0044) 

- 

54 'T 


(0052) 

- 

42 ’B' 


(0053) 

- 

51 ’A' 


(0054) 

- 

54 T 

Ergebnis: 

(0040) 

- 

00, da CAT "größer" als BAT isl. 

b. 

(0041) 

- 

03 


(0042) 

- 

43 C' 


(0043) 

- 

41 A' 


(0044) 


54 T 


(0052) 

- 

43 ’C 


(0053) 

- 

41 ’A' 


(0054) 

- 

54 T 

Ergebnis: 

(0040) 

m 

00, da die beiden Reihen gleich sind 


(0041) 

- 

03 


(0042) 

- 

43 ’C 


(0043) 

- 

41 A’ 


(0044) 


54 T 


(0052) 

- 

43 C 


(0053) 

- 

55 U' 


(0054) 

- 

54 T 

Ergebnis: 

(0040) 

- 

FF, da CUT "größer" als CAT ist. 
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Kapitel 7 

CODE-UMWANDLUNG 


Code-Umwandlung ist eine ständig vorkommende Aufgabe für Mikroprozesso¬ 
ren. Periphere Geräte liefern Daten in ASCII, BCD oder zahlreichen speziellen 
Codes. Der Computer muß diese Daten in binär oder dezimal umwandeln, um 
sie weiter verarbeiten zu können. Ausgangs-Bausteine benötigen Daten in 
ASCII, BCD, Sieben-Segment oder in anderen Codes. Daher muß der Computer 
die Ergebnisse in eine geeignete Form umwandeln, nachdem die Verarbeitung 
beendet ist. 

Es gibt verschiedene Möglichkeiten zur Lösung einer Code-Umwandlung: 

1) Einige Umwandlungen können leicht durch Algorithmen gehandhabt wer¬ 
den, die arithmetische oder logische Funktionen beinhalten. Das Pro¬ 
gramm muß jedoch möglicheiweise einige spezielle Fälle separat verar¬ 
beiten. 

2) Komplexere Umwandlungen können mit Nachschlagetabellen ausgeführt 
werden. Das Verfahren mit den Nachschlagetabellen benötigt wenig Pro¬ 
grammierung und ist leicht anzuwenden Die Tabelle kann jedoch einen 
großen Teil des Speichers belegen, wenn der Bereich der Eingangs¬ 
worte sehr umfangreich ist 

3) Für einige Umwandlungs-Aufgaben gibt es leicht verfügbare Hardware. 

Typische Beispiele sind Decoder für BCD-zu-7-Segmenl-Umwandlung und 
universelle asynchrone Empfänger/Sender (UARTs) für die Umwandlung 
zwischen parallelen (ASCII) und seriellen (Fernschreiber-) Formaten. 

In den meisten Anwendungen sollte das Programm soviel wie möglich von der 
Code-Umwandlung ausführen. Dies ergibt eine Ersparnis an Bauteilen und Platz 
auf der Prinlplatle, sowie erhöhte Zuverlässigkeit. Ferner sind die meisten Code- 
Umwandlungen leicht zu programmieren und benötigen wenig Ausführungszeit. 
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Quellprogramm: 


BEISPIELE 

Hexadezimal in ASCII 

Zweck; Wandle den Inhalt des Speicherplatzes 0040 in ein ASCII Zeichen um. 
Der Speicherplatz 0040 enthält eine einzelne hexadezimale Ziffer (die 
vier höchstwertigen Bils sind null). Speichere das ASCII-Zeichen in den 
Speicherplatz 0041 


Beispiele: 



a. 

(0040) - 

OC 

Ergebnis: 

(0041) - 

43 

b. 

(0040) - 

06 

Ergebnis: 

(0041) - 

36 

Flußdiagramm: 





LDA 

$40 

;HOLE DATEN 

CMP 

#10 

;SIND DATEN KLEINER ALS 1 0? 

BCC 

ASCZ 


ADC 

# A-'9-1 

:NEIN ADDIERE VERSETZUNG FÜR BUCH 
: STABEN(ÜBERTRAG -1) 

ADC 

#'0 

;ADDIERE VERSETZUNG FÜR ASCII 

STA 

BRK 

$41 

.SPEICHERE ASCII-ZIFFER 


Objektprogramm: 


Speicher-Adresse Speicher-Inhalt Befehl 

_(Hex)_(Hex)_ (Mnemonik) 


0000 

A5 

CDA 

$40 

0001 

40 



0002 

C9 

CMP 

*10 

0003 

0A 



0004 

90 

BCC 

ASCZ 

0005 

02 



0006 

69 

ADC 

# A 9 2 

0007 

06 



0008 

69 

ASCZ ADC 

#0 

0009 

30 



000A 

85 

STA 

$41 

000B 

41 



oooc 

00 

BßK 



Der grundlegende Gedanke in diesem Programm besteht in der Addition von 
ASCII Null (30 1s )zu allen hexadezimalen Ziffern Diese Addition wandelt die De- 
zimalzifler korrekt in ASCII um. Es besteht ledoch ein Unterschied zwischen 
ASCII 9 (39|«) und ASCII A (41, 6 ) der berücksichtigt werden muß. Dieser Unter¬ 
schied muß zu den nicht dezimalen Zif ern A. B, C, D, E und F addiert werden 
Dies wird durch den ersten ADC-Befehl durchgeführl, der die Versetzung 'A-'9-2 
zum Inhalt des Akkumulators addiert. Können Sie erklären, weshalb die Verset¬ 
zung gleich A-'9 2 ist? 

Beachten Sie. daß die Additions-Faktoren in das Assembler-Sprachen- 
Programm in ASCII-Form plaziert werden (ein einzelnes Fragezeichen oder 
Apostroph geht einem ASCII-Zeichen voraus). Die Versetzung für die Buchsta¬ 
ben wird als anthmetischer Ausdruck belassen. Der Zweck der Faktoren wird 
hierbei in der Auflistung der Assemblersprache so deutlich wie möglich ge¬ 
macht. Die zusätzliche Assemblierzeit ist sehr klein im Vergleich zum Gewinn 
an Deutlichkeit. 

Erinnern Sie sich daran, daß der ADC-Befehl immer das Übertragsbit addiert. 
Nach dem BCC-Befehl wissen wir, daß der Übertrag eins enthält (andernfalls 
würde eine Verzweigung aufgetrelen sein) So reduzieren wir einfach den addi¬ 
tiven Faktor um 1 um den Übetrag zu berücksichtigen Beim zweiten ADC- 
Befehl wird der Übertrag null sein, wenn das Programm nach dem CMP-Befehl 
verzweigte (da der BCC Befehl verwendet wurde), oder der Akkumulator enthielt 
eine gültige Hexadezimalzahl (1 0 bis 15), da der additive Faktor nur 7 ist. Daher 
brauchen wir uns im allgemeinen nicht um den Übertrag zu kümmern. 
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Diese Routine kann in einer Vielzahl von Programmen verwendet werden Zum 
Beispiel müssen Monitorprogramme hexadezimale Zittern in ASCII umwandeln, 
um den Inhalt von Speicherplätzen in hexadezimal auf einem ASCII-Drucker 
oder auf einem Bildschirm anzuzeigen. 

Eine andere (raschere) Umwandlungs Methode, die überhaupt keine bedingten 
Sprünge benötigt, stellt das folgende Programm dar, das von Allison' beschrie¬ 
ben wurde. 


SED 

CLC 

LDA 

$40 

ADC 

#$90 

ADC 

#$40 

STA 

$41 

CLD 


BRK 



MACHE ADDITION DEZIMAL 
LÖSCHE ÜBERTRAG ZU BEGINN 
HOLE HEXADEZIMALZAHL 
ENTWICKLE ZUSÄTZLICHES UND ÜBER¬ 
TRAG 

ADDIERE ASCII OFFSET IN ÜBERTRAG 
SPEICHERE ASCII-ZlFFER 
LÖSCHE DEZIMAL-BETRIEBSART VOR DEM 
ABSCHLUSS 


Ziffer 

Code 

0 

3F 

t 

06 

2 

5B 

3 

4F 

4 

66 

5 

6D 

6 

7D 

7 

07 

B 

7F 

9 

6F 


Bild 7-1. Sieben-Segment-Anordnung. 


Versuchen Sie das Programm mit einigen Ziffern. Können Sie erklären wie es ar¬ 
beitet? Beachten Sie, daß Sie das Flag für die Dezimalbetriebsart sorgfältig 
löschen müssen, wenn Sie alle dezimalen arilhmefischen Vorgänge beendet 
haben. Andernfalls würden Sie dezimale Ergebnisse in Programmen erhalten 
(einschließlich des Monitors), wo sie nicht erwünscht sind. 


Dezimal in Sieben-Segment 


Beispiel: 

a. (0041) - 03 

Ergebnis: (0042) - 4F 

b. (0041) = 28 

Ergebnis: (0042) ^ 00 


Zweck: Wandle den Inhalt des Speicherplatzes 0041 in einen Sieben-Segment- 
Code im Speicherplatz 0042 um. Wenn der Speicherplatz 0041 keine 
einzelne Dezimalziffer enthält, lösche Speicherplatz 0042. 


Sieben-Segment-Tabelle: Die folgende Tabelle kann zur Umwandlung von Dezi¬ 
malzahlen in den Sieben-Segment-Code verwendet werden. Der Sieben-Seg- 
ment-Code ist so organisiert, daß das höchstwertige Bit immer null ist, gefolgt 
vom Code (1 = ein, 0 - aus) für die Segmente g, (. e, d, c, b und a (siehe Bild 
7-1). 

Die Segment-Bezeichnungen sind standardisiert, die von uns gewählte Organi¬ 
sation ist jedoch willkürlich. In tatsächlichen Anwendungen bestimmt die Hard¬ 
ware die Zuweisung von Datenbils zu den Segmenten. 


Beachten Sie, daß die Tabelle 7D für 6 anstatt 7C (oberer Querbalken ausge¬ 
schaltet) verwendet, um Verwechslung mit dem kleinen b zu vermeiden, und 6F 
für 9 anstatt 67 (unterer Querbalken aus), jedoch aus keinem bestimmten 
Grund 
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Flußdiagramm: 


Objektprogramm: 



Beachten Sie, daß die Addition der Basis-Adresse (SSEG) mit dem Index 
(DATA) die Adresse ergibt, welche die Antwort enthält. 


Quellprogramm: 


LDA #0 

LDX $41 
CPX #10 
BCS DONE 
LDA SSEG.X 

DONE STA $42 

BRK 

*-$20 

SSEG BYTE 
BYTE 


;HOLE FEHLER CODE ZUM AUSTASTEN 
, DER ANZEIGE 
HOLE DATEN 

;SIND DATEN EINE DEZIMALZIFFER? 

;NEIN, BEWAHRE FEHLERCODE AUF 
;JA, HOLE SIEBEN -SEGMENTCODE AUS 
; TABELLE 

;BEWAHRE SIEBEN-SEGMENTCODE ODER 
; FEHLERCODE AUF 

;SIEBEN-SEGMENT-CODETABELLE 
$3F, $06.$5B,$4F, $66 
$6D, $7D, $07, $7F, $6F 


Speicher-Adresse Speicher-Inhalt Betehl 

(Hex) (Hex) (Mnemonik) 


0000 

A9 

LDA 

#0 

0001 

00 



0002 

A6 

LDX 

$41 

0003 

41 



0004 

E0 

CPX 

A10 

0005 

0A 



0006 

BO 

BCS 

DONE 

0007 

02 



0008 

85 

LDA 

SSEG X 

0009 

20 



000A 

85 

DONE STA 

$42 

0008 

42 



oooc 

00 

BRK 


0020 

3F 

SSEG ■BYTE 

$3F 

0021 

06 


$06 

0022 

5B 


$5B 

0023 

4F 


$4F 

0024 

66 


$66 

0025 

6D 

.BYTE 

$6D 

0026 

7D 


$7D 

0027 

07 


$07 

002B 

7F 


$7F 

0029 

6F 


$6F 


Das Programm berechnet die Speicher-Adresse des gewünschten Codes durch 
Addition des Index (d.h. die darzustellende Ziffer) zur Basis-Adresse der 
7-Segment-Codetabelle. Das Verfahren ist als Nachschlagen in einer Tabelle 
bekannt. Es sind keine besonderen Befehle für die Addition erforderlich, da sie 
automatisch in den indizierten Adressier-Arten ausgeführt werden. 

Die Pseudo-Operation BYTE der Assemblersprache plaziert konstante Daten in 
den Programmspeicher. Derartige Daten können Tabellen, Nachrichten-Köpfe, 
Fehlermeldungen, Formatzeichen, Schwellen etc. beinhalten. Die Marke, die zu 
einer Pseudo-Operation BYTE gehöit, wird dem Weit der Adresse zugewiesen, 
in die das erste Datenbyte plaziert wird. 

Für Code-Umwandlungen werden häufig Tabellen veiwendet, die wesentlich 
komplexer als das vorhergehende Beispiel sind. Derartige Tabellen enthalten 
typisch alle Ergebnisse, die entsprechend der Eingangsdaten organisiert sind 
(die ersteEingabe ist der Code, der der Zahl Null entspricht). 

Sieben-Segment-Anzeigen liefern gut lesbare Formen für die Dezimalziffern und 
einige wenige Buchstaben sowie andere Zeichen. Rechnerartige Sieben-Seg¬ 
ment-Anzeigen sind preisgünstig, leicht zu kombinieren und benötigen wenig 
Leistung. Die sieben-segment-codierten Ziffern sind jedoch etwas schwierig zu 
lesen. 
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Der Assembler plaziert einfach die Daten für die Tabelle in den Speicher 
Beachten Sie. daß eine einzelne Pseudo-Operation .BYTE zahlreiche Speicher 
platze füllen kann. 

Wir haben etwas Speicherplatz zwischen dem Programm und der Tabelle frei¬ 
gelassen. um spätere Ergänzungen oder Korrekturen einfügen zu können 

Die Tabelle kann überall in den Speicher plaziert werden, obwohl die absolute 
indizierte Adressier Art zu verwenden wäre, wenn sie nicht auf der Nullseile 
liegt. Wir könnten auch Nach-Indizierung (mit Indexregister Y) verwenden und 
die Basis-Adresse in zwei Speicherbytes auf der Nullseile aufbewahren. Das 
gleiche Programm könnte dann mit jeder beliebigen Tabelle verwendet werden, 
da die Basis-Adresse im RAM anstatt iin ROM spezifiziert würde. 


ASCII in dezimal 

Zweck: Wandle den Inhalt des Speicherplatzes 0040 von einem ASCII-Zeichen 
in eine Dezimalziffer um und speichere das Ergebnis in den Speicher¬ 
platz 0041. Wenn der Inhalt des Speicherplatzes 0040 nicht die ASCII- 
Darstellung einer Dezimalziffer ist, setze den Inhalt des Speicherplatzes 
0041 auf FF,». 


Beispiele: 



a. 

(0040) - 37 

(ASCII 7) 

Ergebnis: 

(0041) - 07 


b. 

(0040) - 55 


Ergebnis: 

(0041) - FF 

(ein ungültiger Code, da er keine ASCII 
Dezimalziffer ist). 

Flußdiagramm: 
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Quellprogramm: 

LDX #$F 
LOA $40 
SEC 

SBC #0 
BCC DONE 
CMP *10 
BCS DONE 
TAX 

DONE STX $41 
BRK 

Objektprogramm: 

Speicher-Adresse Speicher Inhalt Befehl 

(Hex) (Hex) _(M nemonik) 

0001 
0002 
0003 
0004 
0005 
0006 
0007 
0008 
0009 
000A 
000B 

oooc 
0000 
OOOE 
000F 
0010 

Dieses Programm verarbeitet ASCII-codierte Zeichen so wie gewöhnliche Zah¬ 
len. Beachten Sie. daß die Dezimalzittern und die Buchstaben Gruppen von auf¬ 
einanderfolgenden Codes bilden. Reihen (Stnngs) von Buchstaben (wie Namen) 
können in alphabetischer Reihenfolge geordnet werden, indem ihre ASCII-Dar- 
stellungen mit steigender numerischer Ordnung (ASCII B = ASCII A + 1, bei¬ 
spielsweise) plaziert werden 

Das Subtrahieren von ASCII 0 (30, 6 ) von einer ASCII Dezimalziffer ergib) die 
BCD-Darstellung dieser Ziffer 

Der Übertrag muß vor einer Subtraktion gesetzt werden, wenn er das Ergebnis 
nicht beeinflussen soll, da der SBC-Befehl (A) - (A) - (M) - (1 - Ubeitrag) er¬ 
zeugt, wobei M der Inhalt des adressierten Speicherplatzes ist Vergleichsbe¬ 
fehle beinhalten andererseits nicht den Übertrag in den in ihnen enthaltenen 
Subtraktionen, 

Eine Umwandlung ASCII in dezimal ist erforderlich, wenn Dezimalzahlen von ei¬ 
nem ASCII-Gerät, wie einem Fernschreiber oder einem Bildschirm-Terminal, 
eingegeben werden. 


A2 

LDX 

#$FF 

FF 



A5 

LDA 

$40 

40 



38 

SEC 


E9 

SBC 

#0 

30 



90 

BCC 

DONE 

05 



C9 

CMP 

#10 

0A 



B0 

BCS 

DONE 

01 



AA 

TAX 


86 

DONE STX 

$41 

41 



00 

BRK 



.HOLE FEHLER-MITTEILUNG 
HOLE DATEN 

;IGNORIERE ÜBERTRAG BEI SUBTRAKTION 
.SIND DATEN UNTER ASCII-NULL? 

;JA, KEINE ZIFFER 

;SIND DATEN ÜBER ASCII-NEUN? 

;JA. KEINE ZIFFER 

BEWAHRE ZIFFER AUF FALLS GÜLTIG 
;BEWAHREZIFFER ODER FEHLERMARKIE- 
; RUNG AUF 
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Der grundlegende Gedanke dieses Programmes besteht in der Feststellung, ob 
das Zeichen zwischen ASCII 0 und ASCII 9 (einschließlich) liegt. Wenn dies der 
Fall ist, so ist es eine ASCII Dezimalziffer, da die Ziffern eine Sequenz bil¬ 
den, Sie kann dann einfach in dezimal umgewandelt werden, indem 30,6 
(ASCII 0) subtrahiert wird. Zum Beispiel: ASCII 7 -ASCII 0 - 7 - 0 - 7. 

Beachten Sie, daß ein Vergleich mittels einer tatsächlichen Subtraklion 
(SBC #'0) ausgeführt wird, da die Subtraktion zur Umwandlung von ASCII in de¬ 
zimal erforderlich ist Der andere Vergleich wird mittles einer implizierten Sub¬ 
traktion (CMP# 10) durchgeführt. da das endgültige Ergebnis nun im Akkumu¬ 
lator liegt, wenn die Ursprungszahl gültig ist. 

BCD in binär 

Zweck: Wandle zwei BCD-Stellen in den Speicherplätzen 0040 und 0041 in eine 
Binärzahl im Speicherplatz 0042 um. Die höchstwertige BCD-Stelle liegt 
im Speicherplatz 0040. 


Beispiele: 


a. 

(0040) - 02 


(0041) = 09 

Ergebnis: 

(0042) - ID,e = 2g 10 

b. 

(0040) - 07 


(0041) = 01 

Ergebnis: 

(0042) - 47,6 = 71 10 


Anmerkung: Es wird kein Flußdiagramm angegeben, da das Programm die 
höchstwertige Stelle mit 10 multipliziert, indem es einfach die For¬ 
mel lOx =8x + 2x verwendet. Die Multiplikation mit 2 erfordert eine 
arithmetische Links-Verschiebung und die Multiplikation mit 8 be¬ 
nötigt drei derartige Verschiebungen 

Quellprogramm: 


LDA 

$40 

;HOLE HÖCHSTWERTIGE STELLE (MSD) 

ASL 

A 

MULTIPLIZIERE MSD MIT 2 

STA 

$42 

;BEWAHRE DOPPELTES MSD AUF 

ASL 

A 

;MSD MAL4 

ASL 

CLC 

A 

;MSD MAL8 

ADC 

$42 

;MSD MAL 10 (KEIN ÜBERTRAG) 

ADC 

$41 

;ADDIERE NIEDRIGSTWERTIGE STELLE 

STA 

BRK 

$42 

;SPEICHERE BINARES ÄQUIVALENT 
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Objektprogramm: 


Umwandlung einer Binärzahl in eine ASCII-Reihe 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) 

0000 

A5 

LDA 

$40 

0001 

40 



0002 

OA 

ASL 

A 

0003 

85 

STA 

$42 

0004 

42 



0005 

OA 

ASL 

A 

0006 

OA 

ASL 

A 

0007 

18 

CLC 


0008 

65 

ADC 

$42 

0009 

42 



OOOA 

65 

ADC 

$41 

0006 

41 



OOOC 

85 

STA 

$42 

000D 

42 




00 

BRK 



BCD Eingaben werden in binär umgewandelt, um Speicherplatz zu sparen und 
Berechnungen zu vereinfachen. Die Umwandlung kann jedoch einige Vorteile 
der binären Speicherung und Arithmetik aufheben. 

Dieses Programm multipliziert die BCD-Zahl im Speicherplatz 0040 mit 10 unter 
Vei~wendung von Links-Verschiebungen und Additionen*. Beachten Sie, daß 
ASL A den Inhalt des Akkumulators mit 2 multiplizieren. Dies gestattet Ihnen 
den Inhalt des Akkumulators mit kleinen Dezimalzahlen und wenigen Befehlen 
zu multiplizieren. Wie würden Sie dieses Verfahren verwenden, um mit 16 zu 
multiplizieren? Mil 12? Mit 7? 

BCD-Zahlen benötigen etwa 20% mehr Speicher als Binärzahlen. Die Darstel¬ 
lung von 0 bis 999 benötigt 3 BCD-Slellen (12 Bits) und 10 Bits in binär (da 2'° - 
1024 =, 1000). 


Zweck: Wandle die 8-Bit Binärzahl im Speicherplatz 0041 in acht ASCII-Zeichen 
(entweder ASCII 0 oder ASCII 1) in den Speicherplätzen 0042 bis 
0049(das höchstwertige Bit liegt in 0042) um. 

Beispiel: 


(0041) = D2 = 11010010 

Ergebnis: (0042) - 31 ASCI11 

(0043) - 31 ASCI11 
(0044) = 30 ASCII0 
(0045) = 31 ASCII 1 
(0046) - 30 ASCII 0 
(0047) = 30 ASCII0 
(0048) - 31 ASCII 1 
(0049) - 30 ASCII0 

Flußdiagramm: 
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Quel Programm: 



LDA 

$41 

HOLE DATEN 


LDX 

#8 

ANZAHL DER BITS 8 


LDY 

#*0 

HOLE ASCII NULL ZUR SPEICHERUNG IN 




REIHE 

CONV 

STY 

$ 41. X 

SPEICHERE ASCII NULL IN REIHE 


LSR 

A 

IST NÄCHSTES DATENBIT NULL 


BCC 

COUNT 



INC 

$41 ,X ;NEIN, MACHE STRING ELEMENT ASCII EINS 

COUNT 

DEX 

;ZÄHLE BITS 


BNE 

CONV 



BRK 




Objektprogramm: 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 


Befehl 

(Mnemonik) 

0000 

A5 


LDA 

$41 

0001 

41 




0002 

A2 


LOX 

#8 

0003 

08 




0004 

A0 


LDY 

#'0 

0005 

30 




0006 

94 

CONV 

STY 

$41.X 

0007 

41 




0008 

4A 


LSR 

A 

0009 

90 


BCC 

COUNT 

000A 

02 




OOOB 

F6 


INC 

$41.X 

oooc 

41 




000D 

CA 

COUNT 

DEX 


000E 

DO 


BNE 

CONV 

000F 

F6 




0010 

00 


BRK 



Die ASCII Ziffer bilden eine Sequenz, deshalb isl ASCII 1 - ASCII 0 + 1. 

Der INC-Befehl kann zum direklen Inkremenlieren eines Speicherplalzes ver¬ 
wende! werden. Die Ersparnis beslehl darin, daß keine speziellen Befehle erfor¬ 
derlich sind, um die Daten vom Speicher zu laden oder das Ergebnis in den 
Speicher zurückzulegen. Ferner werden keine der Anwender-Register (A. X und 
Y) zerstört. Die CPU muß jedoch tatsächlich die Daten vom Speicher laden, sie 
in einem zeitweiligen Register aufbewahren, mkrementieren und das Ergebnis in 
den Speicher zurückladen. Die gesamte Verarbeitung der Daten geschieht in 
Wirklichkeit innerhalb der CPU. 

Beachten Sie vor allem den Unterschied zwischen INX und einem Befehl wie 
INC $41,X. Der Befehl INC addieit Eins zum Inhalt des Indexregisters X. 
INC $41 ,X addieit Eins zum Inhalt des indizierten Speicherplatzes, er hat keinen 
Einfluß auf das Indexregister X. 

Eine Umwandlung binär in ASCII isl nötig, wenn Zahlen in Binärform auf einem 
ASCII-Geräl ausgedruckt werden. 

Die Umwandlung in ASCII beinhaltet einfach die Addition von ASCII Null (30,«) 


AUFGABEN 

1) ASCII in hexadezimal 

Zweck: Wandle den Inhalt des Speicherplatzes 0040 in eine Hexadezimalzahl 
um und speichere das Ergebnis in den Speicherplatz 0041, Es werde 
angenommen, daß der Speicherplatz 0040 die ASCII-Darstellung einer 
Hexadezimalziffer enthält (7 Bits mit MSB 0). 


Beispiele: 



a. 

(0040) - 43 

ASCII C 

Ergebnis: 

(0041) - 0C 


b. 

(0040) - 36 

ASCII 6 

Ergebnis: 

(0041) - 06 



2} Sieben-Segment in dezimal 

Zweck: Wandle den Inhalt des Speicherplatzes 0040 von einem Sieben- 
Segment-Code in eine Dezimalzahl im Speicherplatz 0041 um. 
Wenn der Speicherplatz 0040 keinen gültigen Sieben-Segmenl- 
Code enthält, setze Speicherplatz 0041 auf FF, 8 . Verwende die 
Sieben-Segmenl-Tabelle, die bei dem Beispiel über die Umwand¬ 
lung dezimal in Sieben-Segment angegeben wurde und versuche 
die Codes in Übereinstimmung zu bringen. 


Beispiele: 


a. 

(0040) - 4F 

Ergebnis: 

(0041) - 03 

b. 

(0040) - 28 

Ergebnis: 

(0041) - FF 

3) Dezimal in ASCII 


Zweck: Wandle den Inhalt des Speicherplatzes 0040 von einer Dezimalzifler in 
ein ASCII-Zeichen um und speichere das Ergebnis in den Speicherplatz 
0041. Wenn die Zahl im Speicherplatz 0040 keine Oezimalziffer ist, 
setze den Inhalt des Speicherplatzes 0041 auf ein ASCII-Leerzeichen 
( 20 , 6 ). 


Beispiele: 



a. 

(0040) - 07 


Ergebnis: 

(0041) - 37 

ASCII 7 

b. 

(0040) - 55 


Ergebnis: 

(0041) - 20 

ASCII SPACE 
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LITERATUR 


4) Binär in BCD 

Zweck: Wandle den Inhalt des Speicherplatzes 0040 in zwei Dezimalstellen 
im Speicherplatz 0041 und 0042 um (höchstwertige Stelle in 0041). 
Die Zahl im Speicherplatz 0040 besitzt kein Vorzeichen und ist klei¬ 
ner als 100. 


Beispiele: 


a. 

(0040) 


ID 

(29 dezimal) 

Ergebnis: 

(0041) 

- 

02 



(0042) 


09 


b. 

(0040) 


47 

(71 dezimal) 

Ergebnis: 

(0041) 

- 

07 



(0042) 

- 

01 



1) Allison, D. R., "A Design Philosophie for Microcomputer Architectures". Com¬ 
puter. Februar 1977, Seite 35-41. Ein außerordentlich empfehlenswerter 
Artikel. 

2) Weitere Verfahren für die Umwandlung BCD in binär werden besprochen in 
J A Tabb and M L. Roginsky, "Microprocessor Algorithms Make BCD-Binary 
Conversions Super-fast." EDN, January 5, 1977, pp. 46-50 and in J B Peat- 
man, Microcomputer-based DesiatL (New York: McGraw-Hill, 1977, pp. 
400-406. 


5) Binärzahl in ASCII-Reihe 

Zweck: Wandle die acht ASCII-Zeichen in den Speicherplätzen 0042 bis 0049 in 
eine 8-Bit-Binärzahl im Speicherplatz 0041 um (das höchstwertige Bit 
liegt in 0042). Lösche den Speicherplatz 0040, wenn alle ASCII-Zeichen 
entweder ASCII 1 oder ASCII 0 sind und setze anderenfalls auf 


ff 16 . 





Beispiele: 

a. 

(0042) 


31 

ASCII 1 


(0043) 

- 

31 

ASCII 1 


(0044) 

- 

30 

ASCII 0 


(0045) 

- 

31 

ASCII 1 


(0046) 

- 

30 

ASCII 0 


(0047) 

- 

30 

ASCII 0 


(0048) 

- 

31 

ASCII 1 


(0049) 


30 

ASCII 0 

Ergebnis: 

(0041) 


D2 


b. gleich wie ”a” 

(0040) - 00 

mit Ausnahme: 



(0045) 


37 

ASCII 7 

Ergebnis: 

(0040) 

- 

FF 
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Kapitel 8 

ARITHMETISCHE AUFGABEN 


Die meisten arithmetischen Aufgaben bei Mikroprozessor-Anwendungen be¬ 
stehen in der Verarbeitung von Binär- oder Dezimaizahlen, die aus mehreren 
Woiten bestehen. Eine Dezimal-Korrektur (decimal adjust) oder einige andere 
Hilfsmittel zur Ausführung dezimaler Arithmetik ist häufig der einzige arithme¬ 
tische Befehl, der neben der grundlegenden Addition und Subtraktion vorgese¬ 
hen ist. Andere arithmetische Operationen muß man mit Befehlssequenzen 
ausführen. 

Binär-Arithmetik mit mehrfacher Genauigkeit erfordert einfache Wiederholun¬ 
gen der grundlegenden Einwort-Befehle. Das Übertrags-Bit transferiert Informa¬ 
tionen zwischen Worten. Addition mit Übertrag und Subtraktion mit Übertrag 
verwenden die Information von den vorhergehenden arithmetischen Operatio¬ 
nen. Man muß sorgfältig darauf achten, den Übertrag zu löschen, bevor man die 
ersten Worte bearbeitet (offensichtlich gibt es keinen Übertrag in, oder 
"Borgen” von den niedrigstwertigen Bits). 

Die Dezimal-Arithmetik ist eine so häufige Aufgabe für Mikroprozessoren, daß 
die meisten spezielle Befehle für diesen Zweck besitzen. Diese Befehle können 
entweder dezimale Operationen direkt ausführen oder die Ergebnisse von binä¬ 
ren Operationen in die entsprechende Dezimalform anordnen. Die Dezimal- 
Arithmetik ist wesentlich in Anwendungen wie Registrierkassen, Rechner, Auf¬ 
trags-Eingabesysteme und Bank-Terminals. 

Man kann Multiplikation und Division als eine Serie von Additionen und Subtrak¬ 
tionen ausführen. Operationen an Doppelworten sind erforderlich, da eine Multi¬ 
plikation ein Ergebnis liefert, das doppelt so lang wie die Operanden sind, wäh¬ 
rend ähnlich eine Division die Länge des Ergebnisses verringert Multiplikatio¬ 
nen und Divisionen benötigen viel Zeit, wenn sie von der Software ausgeführt 
werden, da hierfür wiederholte arithmetische und Schiebe-Operationen 
erforderlich sind. Natürlich ist eine Multiplikation oder Division durch eine Po¬ 
tenz von 2 sehr einfach, da derartige Operationen mit einer entsprechenden An¬ 
zahl von arithmetischen Rechts- oder Links-Verschiebungen ausgeführt werden 
können. 
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BEISPIELE 

Addition mit mehrfacher Genauigkeit 

Zweck: Addiere zwei Binärzahlen aus mehreren Worten Die Länge der Zahlen 
(in Bytes) befindet sich im Speicherplatz 0040, die Zahl selbst beginnt 
(höchstwertige Bits zuerst) entsprechend in den Speicherplätzen 0041 
und 0051, und die Summe ersetzt die Zahl, die im Speicherplatz 0041 
beginnt. 

Beispiel: 

(0040) = 04 

(0041) = 2F 
(0042) = 5B 
(0043) = A7 
(0044) - C3 

(0051) ~ 14 
(0052) - DF 
(0053) - 35 
(0054) - B8 

Ergebnis: (0041) = 44 

(0042) = 3A 
(0043) = DD 
(0044) = 7B 


das heißt: 2F5BA7C3 

+1 4DF35B8 
443AD07B 
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Flußdiagramm: 



Quellprogramm: 


ADDW 


LDA 

$40 

;INDEX = LÄNGE DER REIHEN 

CLC 


iLÖSCHE ÜBERTRAG BEI START 

LDA 

$40,X 

;HOLE BYTE VON REIHEI 

ADC 

$50,X 

;ADOIERE BYTE VON REIHE 2 

STA 

DEX 

$40,X 

;SPEICHERE ERGEBNIS IN REIHE 1 

BNE 

BRK 

ADDW 

;SETZE FORT BIS ALLE BYTES ADDIERT 
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Objektprogramm: 


Dezimale Addition 


Speicher Adresse 
(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) 

0000 

A6 

LDX 

$40 

0001 

40 



0002 

18 

CLC 


0003 

85 

ADDW LDA 

$40,X 

0004 

40 



0005 

75 

ADC 

$50,X 

0006 

50 



0007 

95 

STA 

$40.X 

0008 

40 



0009 

CA 

OEX 


000A 

DO 

BNE 

ADDW 

000B 

F7 



OOOC 

00 

BRK 



Die relative Adresse für BNE ADDW ist 

0003 03 

-000C +F4 

F7 

Der Befehl CLC löscht das Übertragsbit. Der Übertrag muß gelöscht 
werden, da bei der Addition der niedrigstwertigen Bytes kein Übertrag 
enthalten sein kann. 

Der Befehl ADC, (ADD WITH CARRY) enthält den Übertrag von den vor¬ 
hergehenden Worten der Addition ADC ist der einzige Befehl in der 
Schleife, der den Übertrag beeinflußt. Beachten Sie, daß weder ln- 
krementiert- noch Dekrementier-Befehle (DEC, DEX, DEY. INC, INX, INY) 
den Übertrag nicht beeinflußen. 

Dieses Programm verwendet den gleichen Index mit 
zwei verschiedenen Basis Adressen, um die beiden Reihen 
zu handhaben. Die Reihen können überall in den Speicher 
gelegt werden. Ferner wäre es nicht schwierig, das Ergebnis in 
abzuspeichern. 

Dieses Verfahren kann Binärzahlen jeder Länge addieren. Beachten Sie, daß 
zehn binäre Bits drei dezimalen Stellen entsprechen, da 2'*= 1 024 1000. 

Daher kann man die Anzahl der erforderlichen Bits berechnen, um eine 
bestimmte Genauigkeit in Dezimalstellen anzugeben. Zum Beispiel be¬ 
nötigt eine zwölfstellige Dezimalzahl 


DEZIMALE 
GENAUIGKEIT 
IN BINÄR 


eine dritte Reihe 


12 x 40 Bits 


Zweck: Addiere zwei Dezimai(BCD)-Zahlen aus mehreren Worten. Die 
Länge der Zahlen befindet sich im Speicherplatz 0040, die 
Zahlen selbst beginnen (höchstwertige Bits zuerst) entsprechend 
in den Speicherplätzen 0041 und 0051, und die Summe ersetzt 
die Zahl, die im Speicherplatz 0041 beginnt 

Beispiel: 


Ergebnis: 


das heißt: 


Flußdiagramm: 


(0040) 


04 

(0041) 

= 

36 

(0042) 


70 

(0043) 

- 

1 9 

(0044) 


85 

(0051) 

- 

1 2 

(0052) 

= 

66 

(0053) 

- 

34 

(0054) 


59 

(0041) 

= 

49 

(0042) 

= 

36 

(0043) 

= 

54 

(0044) 

= 

44 


36701985 

+12663459 

49365444 



(Oieser Schritt eizeu 
neuen Übertrag) 


auch einen 
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Quellprogramm: 


AOOW 


SED 


LDX 

CLC 

$40 

LDA 

$40,X 

ADC 

$50,X 

STA 

DEX 

$40,X 

BNE 

CLD 

BRK 

ADDW 


MACHE OIE ARITHMETIK DEZIMAL 
INDEX- LÄNGE DER REIHEN 
LÖSCHE ÜBERTRAG BEI START 
HOLE ZWEI STELLEN VON REIHE 1 
ADDIERE ZWEI STELLEN VON REIHE 2 
SPEICHERE ERGEBNIS IN REIHE 1 

;SETZE FORT BIS ALLE STELLEN ADDIERT 
;KEHRE ZUR BINÄR BETRIEBSART ZURÜCK 


Objektprogramm: 


Speicher Adresse 
(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) 

0000 

F8 

SED 


0001 

A6 

LDX 

$40 

0002 

40 



0003 

18 

CLC 


0004 

B5 

ADDW LDA 

$40,X 

0005 

40 



0006 

75 

ADC 

$50,X 

0007 

50 



0008 

95 

STA 

$40.X 

0009 

40 



000A 

CA 

DEX 


0008 

DO 

BNE 

ADDW 

oooc 

F7 



000D 

08 

CLD 


000E 

00 

BRK 



Die Dezimal-Betriebsart berücksichtigt automa¬ 
tisch folgende Situationen, in denen sich Binär- 
und BCD-Addition unterscheiden. 

1) Die Summe zweier Ziffern liegt zwischen 10 und ein 
schließlich 15. In diesem Fall muß sechs zur Summe addiert werden, um das 
richtige Ergebnis zu liefern, d.h.: 

0101 (5) 

+ 1000 ( 8 ) 

1101 (D) 

+ 0110 

0001 0011 (BCD 13, das korrekt ist) 

2) Die Summe von zwei Ziffern ist 16 oder größer. In diesem Fall ist das Ergeb¬ 
nis eine richtige BCD-Zahl, jedoch sechs weniger, als es sein sollte, d.h 


DEZIMAL¬ 

BETRIEBSART 

DES6502 


Sechs muß in beiden Fällen addiert werden. Jedoch kann Fall 1 durch dieTatsa- 
che erkannt werden, daß die Summe keine BCD-Ziffer ist. Sie liegt zwischen 10 
und 15 (oder A und F hexadezimal). Fall 2 kann nur durch die Tatsache erkannt 
werden, daß der Übertrag aus der Addition einer Stelle eins ist, da das Ergebnis 
eine gültige BCD-Zahl ist. 

Wenn das Flag für die Dezimal-Betriebsart gesetzt ist, wird die gesamte 
Arithmetik in dezimaler Form ausgefühlt. Dies beinhaltet sowohl Subtraktio¬ 
nen als auch Additionen, unabhängig davon, welche Adressier-Art angewendet 
wird. 

Die Inkremtier- und Dekrementier-Befehie er¬ 
zeugen jedoch binäre Ergebnisse, auch wenn 
das Flag für die dezimale Betriebsart gesetzt 
ist. 

Daher kann OEC, OEX. DEV, INC, INY und INX nur für binäre Zähler ver¬ 
wendet werden. Um zum Beispiel einen Dezimalzähler im Speicher¬ 
platz 0040 zu inkrementieren, müssen Sie folgende Sequenz verwenden. 


SED 


;MACHE ARITHMETIK DEZIMAL 

LDA 

$40 

;HOLE ZÄHLER 

CLC 


;HINDERE ÜBERTRAG AM BEEINFLUSSEN 
; DER ADDITION 

ADC 

#1 

;INKREMENTIERE ZÄHLER (DEZIMAL) 

STA 

$40 

CLD 


;KEHRE ZU BINÄRER BETRIEBSART 
; ZURÜCK 


Die Befehle SED, CLC und CLD können nicht erforderlich sein, wenn 
andere Teile des Programmes die Statusflags entsprechend setzen. 

Subtraktionen in der Dezimal-Betriebsait erzeugen korrekte BCD-Ergebnisse 
mit dem Übertrag, der ein invertiertes "Borgen" darstellt. Wenn zum Beispiel der 
Akkumulator 03 enthält, der adressierte Speicherplatz 27 und der Übertrag 1 ist, 
so wird nach Ausführung eines SBC-Befehls der Akkumulator 76 enthalten und 
der Übertrag 0 sein. Wie bei der binären Betriebsart bedeutet ein Übertrag von 
0, daß ein Borgen erzeugt wurde. 

Das Vorzeichen-Bit hat keine Bedeutung nach Additionen und Subtraktionen, 
wenn das Flag für die Dezlmai-Betrlebsaart gesetzt ist. Es gibt das Ergebnis ei¬ 
ner binären Operation wieder, nicht das einer dezimalen Operation. In der kürz¬ 
lich erwähnten Situation (03-27) wird das Vorzeichen-Bit gesetzt (wie es der Fall 
sein würde, wenn die Zahlen binär wären), auch wenn das dezimale Ergebnis 
(76) ein höchst wertiges Bit von 0 besitzt. 

Dieses Verfahren kann Dezimal- (BCD-)Zahlen jeder 
Länge verarbeiten. Hier sind vier binäre Bits für jede 
Dezimalstelle erforderlich, so daß 12 x 4 = 48 Bits 
eine zwölfstellige Genauigkeit erfordert, im Gegensatz zu 40 Bits im binären 
Fall. Dies sind sechs 8-Bit-Worte anstatt fünf. 


GENAUIGKEITIN 
BINÄR UND BCD 


GRENZEN DER 
DEZIMAL¬ 
BETRIEBSART 


1000 ( 8 ) 

+ 1001 (9) 

0001 0001 (BCD 11) 

+ 0110 

0001 0111 (BCD 17, das korrekt ist) 
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8-Bit-Binärmultjplikation 

Zweck: Multipliziere die 8 Bit-ZahI ohne Vorzeichen im Speicherplatz 0040 mit 
der 8 Bit-Zahl ohne Vorzeichen im Speicherplatz 0041. Plaziere die acht 
niedrigstwertigen Bits des Ergebnisses in den Speicherplatz 0042 und 
die acht höchstwertigen Bits in den Speicherplatz 0043. 

Beispiele: 

a. (0040) - 03 

(0041) - 05 

Ergebnis: (0042) - 0F 

(0043) = 00 
oder in dezimal 3x5-15 

(0040) - 6F 
(0041) - 61 

Ergebnis: (0042) - OF 

(0043) = 2A 
oder 111 x 97 = 10 767 

Man kann eine Multiplikation auf einem Computer auf die gleiche Weise ausfüh¬ 
ren, wie man es manuell bei einer langen Multiplikation macht. Da es sich um 
Binärzahlen handelt, besteht die einzige Aufgabe darin, mit Oodermit 1 zu mul¬ 
tiplizieren. Die Multiplikation mit null ergibt offensichtlich null als Ergebnis, wäh¬ 
rend eine Multiplikation mit eins die gleiche Zahl ergibt, mit der man begonnen 
hat (dem Multiplikand). Daher kann jeder Schritt in einer Binär-Multiplikation aut 
die folgende Operation reduziert werden: 

Wenn das momentane Bit im Multiplikator 1 ist, MULTIPLIKATIONS- 

addiere den Multiplikanden zum Teilprodukt. ALGORITHMUS _ 

Das einzige verbleibende Problem besteht darin, daß man alles zu jeder Zeit 
korrekt gruppiert Die folgenden Operationen führen diese Aufgabe aus: 

1) Verschiebe Multiplikator um ein Bit nach links, so daß das zu prüfende Bit in 
den Übertrag plaziert wird. 

2) Verschiebe Produkt um ein Bit nach links, so daß die nächste Addition kor¬ 
rekt angeordnet ist 

Der vollständige Vorgang für eine Binär-Multiplikation ist wie folgt: 

Schritt 1 - Initialisierung 
Produkt = 0 
Zähler» 8 

Schritt 2 - Schiebe Produkt so, daß es richtig angeordnet ist. 

Produkt = 2x Produkt (LSB = 0) 

Schritt 3 - Schiebe Multiplikator so, daß das Bit in den Übertrag gelangt. 
Multiplikator» 2 x Multiplikator 

Schritt 4-Addiere Multiplikand zum Produkt, wenn der Übertrag 1 ist. 

Wenn Übertrag» 1, Produkt- Produkt+ Multiplikand 
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Schritt 5 - Dekrementiere Zähler und prüfe auf null 
Zähler- Zähler-1 

Wenn Zähler ^ 0, gehe zu Schritt 2 

Im Falle des Beispiels b, in dem der Multiplikator 61i S und der Multiplikand 6F 1S 

ist, arbeitet das Verfahren wie folgt: 

Initialisierung: 

Produkt 0000 

Multiplikator 61 

Multiplikand 6F 

Zähler 08 

Nach der ersten Wiederholung der Schritte 2-5: 

Produkt 0000 

Multiplikator C2 

Multiplikand 6F 

Zähler 07 

Übertrag vom Multiplikator 0 

Nach der zweiten Wiederholung: 

Produkt 006F 

Multiplikator 84 

Multiplikand 6F 

Zähler 06 

Übertrag vom Multiplikator 1 

Nach der dritten Wiederholung: 

Produkt 014D 

Multiplikator 08 

Multiplikand 6F 

Zähler 05 

Übertrag vom Multiplikator 1 

Nach der vierten Wiederholung: 

Produkt 029A 

Multiplikator 10 

Multiplikand 6F 

Zähler 04 

Übertrag vom Multiplikator 0 

Nach der fünften Wiederholung: 

Produkt 0534 

Multiplikator 20 

Multiplikand 6F 

Zähler 03 

Übertrag vom Multiplikator 0 
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Nach der sechslen Wiederholung; 


Flußdiagramm: 


Produkl 0A68 

Multiplikator 40 

Mulliplikand 6F 

Zähler 02 

Übertrag vom Multiplikator 0 

Nach der siebten Wiederholung; 

Produkl 14D0 

Multiplikalor 80 

Mulliplikand 6F 

Zähler 01 

Übertrag vom Multiplikalor 0 

Nach der achten Wiederholung: 

Produkt 2A0F 

Multiplikator 00 

Multiplikand 6F 

Zähler 00 

Übertrag vom Multiplikator 1 
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Quellprogramm: 



LDA 

#0 

LSB'S DES PRODUKTS- NULL 


STA 

$43 

MSB'S DES PRODUKTS - NULL 


LDX 

#8 

ANZAHL DER BITS IM MULTIPLIKATOR- 8 

SHIFT 

ASL 

A 

VERSCHIEBE PRODUKT UM EIN BIT NACH 




LINKS 


ROL 

$43 



ASL 

$41 

VERSCHIEBE MULTIPLIKATOR NACH LINKS 


BCC 

CHCNT 

KEINE ADDITION WENN NÄCHSTES BIT 




NULL 


CLC 

;ADDIERE MULTIPLIKANT ZUM PRODUKT 


ADC 

$40 



BCC 

CHCNT 



INC 

$43 

MIT ÜBERTRAG FALLS ERFORDERLICH 

CHCNT 

DEX 


SCHLEIFE, BIS 8 BITS MULTIPLIZIERTSIND 


BNE 

SHIFT 



STA 

$42 

SPEICHERE LSB’S DES PRODUKTS 


BRK 




Objektprogramm: 


Speicher Adresse 
(Hex) 

Speicher-Inhalt 

(Hex) 


Befehl 

(Mnemonik) 

0000 

A9 


LDA 

#0 

0001 

00 




0002 

85 


STA 

$43 

0003 

43 




0004 

A2 


LDX 

#8 

0005 

08 




0006 

OA 

SHIFT 

ASL 

A 

0007 

26 


ROL 

$43 

0008 

43 




0009 

06 


ASL 

$41 

OOOA 

41 




000B 

90 


BCC 

CHCNT 

oooc 

07 




000D 

18 


CLC 


000E 

65 


ADC 

$40 

000F 

40 




0010 

90 


BCC 

CHCNT 

oon 

02 




0012 

E6 


INC 

$43 

0013 

43 




0014 

CA 

CHCNT 

DEX 


0015 

•0 


8NE 

SHIFT 

0016 

EF 




0017 

85 


STA 

$42 

0018 

42 




0019 

00 


BHK 



Neben seiner offensichtlichen Verwendung in Rechnern und Registrierkassen ist 
die Multiplikation ein wesentlicher Teil aller Signalverarbeitungs- und Steuer- 
Algonthmen. 

Die Geschwindigkeit, mit der Multiplikationen ausgeführt werden können, be¬ 
stimmen die Nützlichkeit einer CPU in der Prozess-Steuerung, Signal-Erkennung 
und Signal Analyse. 

Dieser Algorithmus benötigt zwischen 170 und 280 Taktzyklen, um auf einem 
6502 zu multiplizieren. Die genaue Zeit hängt von der Anzahl der 1 - Bits im Mul¬ 
tiplikator ab. Andere Algorithmen können die durchschnittliche Zeit etwas ver¬ 
ringern, jedoch werden 250 Taktzyklen für eine Software-Multiplikation typisch 
sein. 

Einige Mikroprozessoren (wie der 9900, 8086 und Z8000) besitzen Befehle für 
eine Hardware-Multiplikation, die etwas schneller ist, wobei jedoch die 
maximale Geschwindigkeit zusätzliche externe Hardware benötigt. 
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8-Bit-Binär-Di Vision 

Zweck: Dividiere die 16-Bil-Zahl ohne Vorzeichen in den Speicherplätzen 0040 
und 0041 (höchstwellige Bits in 0041) durch die 0-Bil Zahl ohne Vor¬ 
zeichen im Speicherplatz 0042. Die Zahlen sind normiert, so daß 1 die 
höchslwerligen Bits sowohl des Dividenden und des Divisors null sind 
und 2 die 2ahl im Speicherplatz 0042 größer als die Zahl im Speicher¬ 
platz 0041 ist. Daher isl der Quotient eine B-Bil-Zahl. Speichere den 
Quotienten in den Speicherplatz 0043 und den Rest in den Speicher¬ 
platz 0044. 

Beispiele: 

a. (0040) = 40 (64 dezimal) 

(0041) = 00 

(0042) - 00 

Ergebnis: (0043) = 00 

(0044) = 00 

i.e. 64/0-0 

b. (0040) = 6D (12 909 dezimal) 

(0041) = 32 

(0042) = 47 (71 dezimal) 

Ergebnis: (0043) = B5 (101 dezimal) 

(0044) = 3A (50 dezimal) 

i.e. 1 2 909/71 - 101 mit einem Rest von 50 


Man kann eine Division mit einem Computer genauso aus- - 

führen, wie man es mit Bleistift und Papier machen würde, DIVISIONS- 
d,h., durch die versuchsweise Verwendung von Subtraktio- ALGORITHMUS 
nen 

Da es sich um Binärzahlen handelt, beslehl die einzige Frage darin, ob das 
Bit im Quotienten 0 oder 1 ist, d.h., ob der Divisor von dem subtrahiert werden 
kann, was vom Dividenden übrig gelassen wurde. Jeder Schrill in einer Binär- 
Divisionkann auf folgende Operationen reduziert werden: 

Wenn der Divisor von den achl höchstwertigen Bits des Di¬ 
videnden ohne "Borgen" subtrahiert werden kann, ist das 
entsprechende Bit im Quolien-len 1. Andernfalls ist es 0. 

Das einzige verbleibende Problem liegt im richtigen Anordnen des Dividenden 
und Quotienten. Man kann dies vor jeder versuchsweisen Subtraktion, durch lo¬ 
gische Linksverschiebung (um ein Bit) des Dividenden und Quotienten ausfüh¬ 
ren. Dividend und Quotient können sich ein 16-Bit-Register teilen, da das Ver¬ 
fahren ein Bit des Dividenden zur gleichen Zeit löscht, in der es ein Bit des Quo¬ 
tienten bestimmt 
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Der vollständige Vorgang für binäre Divisionen ist: 

Schritt 1 - Initialisierung 
Quotient - 0 
Zähler - 8 

Schritt 2 - Verschiebe Dividenden und Quotienten sod. daß sie entsprechend 
angeordnel sind. 

Dividend = 2 x Dividend 
Quotient» 2 x Quotient 

Schrill 3 - Führe Subtraktion versuchsweise aus. Wenn kein "Borgen", addiere 1 
zum Quotienten Wenn 0 MSBs des Dividenden > Divisor, dann sind 
die MSBs des Dividenden— MBS des Dividenden- Divisor, Quotient— 
Quolienl+1. 

Schritt 4 - Dekrementiere Zähler und prüfe auf null 
Zähler-Zähler-1 

wenn der Zähler * 0, gehe zu Schritt 2 
Rest = MBSs des Dividenden 

Im Falle des Beispiels b, in dem der Dividend 326D 1S und der Divisor 47i S ist, 
arbeitet das Verfahren wie folgt: 

Initialisierung: 

Dividend 326D 

Divisor 47 

Quotient 00 

Zähler 00 

Nach der ersten Wiederholung der Schritte 2-4: (Beachten Sie, daß der Divi¬ 
dend vor der versuchsweisen Subtraktion verschoben wird). 

Dividend 1DDA 

Divisor 47 

Quotient 01 

Zähler 07 

Nach der zweiten Wiederholung der Schrille 2-4: 

Dividend 3BB4 

Divisor 47 

Quotient 02 

Zähler 06 

Nach der dritten Wiederholung: 

Dividend 3060 

Divisor 47 

Quotient 05 

Zähler 05 
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Nach der vierlen Wiederholung: 


Dividend 1900 

Divisor 47 

Quotienl OB 

Zähler 04 

Nach der fünflen Wiederholung: 

Dividend 33A0 

Divisor 47 

Quolienl 16 

Zähler 03 

Nach der sechsten Wiederholung: 

Dividend 2040 

Divisor 47 

Quolienl 2D 

Zähler 02 

Nach der siebten Wiederholung: 

Dividend 4080 

Divisor 47 

Quotienl 5A 

Zähler 01 

Nach der achten Wiederholung: 

Dividend 3A00 

Divisor 47 

Quolienl B5 

Zähler 00 

Daher ist der Quolienl B5 und der Resl 3A. 

Die MSBs des Dividenden und Divisors sind angenommen null, um die Berech¬ 
nungen zu vereinfachen (die Verschiebung vor der versuchsweisen Subiraklion 
würde andernfalls das MSB des Dividenden in den Übertrag plazieren). Aufga¬ 
ben. die nicht in dieser Form vorliegen, müssen vereinfacht werden, indem Teile 
des Quotienten entfernt werden, die einen Überlauf eines 8-Bil Wortes bewirken 
würden. Zum Beispiel: 

1024 _ 400 (H e x) 100+ 100jHe*) 


Die letzte Aufgabe befindet sich nun in der richtigen Form. Eine zusätzliche Divi 
sion kann erforderlich sein. 
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Quellprogramm: 



LDX 

#8 

.ANZAHL DER BITS IM DIVISOR - 8 


LDA 

$40 

iSTARTE MIT LSB'S DES DIVIDENDEN 


STA 

$43 



LDA 

$41 

;HOLE MSB S DES DIVIDENDEN 

DIVID 

ASL 

$43 

iVERSCHIEBE DIVIDEND. QUOTIENT UM 1 




; BIT NACH LINKS 


ROL 

A 



CMP 

$42 

;KANN DIVISOR SUBTRAHIERT WERDEN? 


BCC 

CHCNT 

;NEIN, GEHE ZU NÄCHSTEM SCHRITT 


SBC 

$42 

;JA, SUBTRAHIERE QUOTIENTEN (UBER- 




; TRAG = 1) 


INC 

$43 

;UND INKREMENTIERE QUOTIENT U M 1 

CHCNT 

DEX 


tSCHLEIFE BIS ALLE 6 BITS VERARBEITET 


BNE 

DIVID 



STA 

$44 

;SPEICHERE REST 


BRK 




Objektprogramm: 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 


Befehl 

(Mnemonik) 

0000 

A2 


LDX 

#8 

0001 

08 




0002 

A5 


LDA 

$40 

0003 

40 




0004 

85 


STA 

$43 

0005 

43 




0006 

A5 


LOA 

$41 

0007 

41 




0008 

06 

DIVID 

ASL 

$43 

0009 

43 




OOOA 

2A 


ROL 

A 

000B 

C5 


CMP 

$42 

OOOC 

42 




000D 

90 


BCC 

ChCNT 

000E 

04 




000F 

E5 


SBC 

$42 

0010 

42 




0011 

E6 


INC 

$43 

0012 

43 




0013 

CA 

CHCNT 

DEX 


0014 

DO 


BNE 

DIVID 

0015 

F2 




0016 

85 


STA 

$44 

0017 

44 




0018 

00 


BRK 



Die Division wird in Rechnern. Terminals, bei der Prüfung von Übertragungsfeh- 
Jern, Steuer-Algorithmen und zahlreichen anderen Anwendungen eingesetzt. 

Der Algorithmus benötigt zwischen 150 und 230 Mikrosekunden, um eine Divi¬ 
sion auf einem 6502 mit einer Taktfrequenz von 1MHz auszuführen. Die genaue 
Zeit hängt von der Anzahl der 1-Bi'ts im Quotienten ab. Andere Algorithmen kön¬ 
nen die durchschnittliche Zeit etwas verringern, jedoch 200 Mikrosekunden sind 
typisch für eine Software-Division, 

Die Befehle ASL $43 und ROL A ergeben zusammen eine arithmetische Links- 
verschiebung mit 1 6 Bits des Dividenden (MSBs in A). Der ROL-Befehl nimmt 
das Bit auf, das der ASL-Befehf im Übertrag zurückläßt. 

Eine 8-Bit-Subtraktion ist erforderlich, da es keinen einfachen Weg für eine 
16-Bit-Subtraktion oder Vergleich gibt. 

Der Speicherplatz 0043 und der Akkumulator beinhalten sowohl den Dividenden 
als auch den Quotienten Der Quotient ersetzt einfach den Dividenden im Spei¬ 
cherplatz 0043, während der Dividend arithmetisch nach links verschoben wird. 

Wir brauchen uns nicht um den Übertrag in dem SBC-Befeh! zu kümmern. Er 
muß 1 sein, da andernfalls BCC eine Verzweigung bewirkt haben würde. Erin¬ 
nern Sie sich daran, daß ein Übertragsweit von 1 keinen Einfluß auf das Ergeb 
ms eines SBC-Befehls hat, da der Übertrag ein invertiertes "Borgen” darstellt. 


Selbst-prüfende Zahlen 
("Double Add Double Mod 10”) 

Zweck: Berechne eine Prüfsummen-Ziffervon einer Reihe von BCD-Zitlern. Die 
Länge der Reihe der Ziffern (Anzahl der Worte) befindet sich im Spei¬ 
cherplatz 0041. Die Ziffernreihe (2 BCD-Ziffern in einem Wort) beginnt 
im Speicherplatz 0042. Berechne die Prüfsummen-Ziffer mit dem soge¬ 
nannten "Double Add Double Mod ^"-Veitahren 1 und speichere diese 
in den Speicherplatz 0040. 


Das Verfahren "Double Add Double Mod 1 0" 
arbeitet wie folgt; 


1) Lösche zu Beginn die Prüfsumme. 

2) Multipliziere die führende Stelle mit 2 und addiere das Ergebnis zur Prüfsum¬ 
me. 

3) Addiere die nächste Stelle zur Prüsumme. 

4) Setze den abwechselnden Vorgang fort, bis alle Stellen veiwendet wurden. 

5) Die niedrigstwertige Stelle der Prüfsumme ist die selbstprüfende Ziffer. 


SELBST-PRÜFENDE 

ZAHLEN 


8-18 


8-19 






Selbslprufende Ziffern werden gewöhnlich zur Idenlilizierung von Zahlen auf 
Kredilkarten. Invenlur-Elikellen, Gepäck. Pakelen elc. hinzugefügl. wenn sie von 
Compulersyslemen verarbeilel werden. Sie können auch in Ftouline-Mit- 
leilungen, Idenlifizierungs-Dateien und anderen Anwendungen eingeselzl wer¬ 
den Der Zweck der Ziffern besieht in einer Minimisierung von Eingabe-Fehlern, 
wie etwa verlauschle Stellen (69 anstatt 96), verschobene Ziffern (7260 anstatt 
3726), Abweichungen von Ziffern um 1 (65 anslatt 64), elc. Man kann die selbst¬ 
prüfenden Zahlen automatisch auf Richtigkeit der Eingabe überprüfen und man 
kann zahlreiche Fehler sofort eliminieren. 

Oie Analysis der selbslprüfenden Methode ist ziemlich komplex. Beispielsweise 
wird eine glatte Prüfsumme Vertauschungs-Fehler nicht finden (4 + 9 - 9 + 4). 
Oer Algorithmus für das "Oouble Add Double Mod 10" wird einfache Vertau¬ 
schungsfehler festslellen (2x4 + 9=17#2x9+4), wird jedoch einige Fehler 
nicht aufdecken, wie etwa Vertauschungen einer geraden Anzahl von Stellen 
(367 anstatt 763). Trotzdem wird dieses Verfahren zahlreiche allgemeine Fehler 
findenl Oer Wert dieser Methode hängt davon ab, welche Fehler sie feststellen 
wird und von der Wahrscheinlichkeit, mit der spezielle Fehler in einer Anwen¬ 
dung auftrelen. 

Beispielsweise wird das Ergebnis bei einer Reihe von Ziffern 

549321 

folgendes sein: 

Prüfsumme - 5x2 + 4 + 9x2 + 3 + 2x2 + 1 =40 
Selbslprüfende Ziffer^ 0 (niedrigstwertige Stelle der Prüfsumme) 

Beachten Sie, daß eine fehlerhafte Eingabe wie 543921 eine unterschiedliche 
selbslprüfende Ziffer (4) erzeugt, jedoch fehlerhafte Eingaben wie 049321 oder 
945321 nicht festgestellt würden. 

Beispiele: 

a. (0041) - 03 
(0042) - 36 
(0043) - 68 
(0044) - 51 

Ergebnis: Prüf summe - 3x2+6 + 6x2 + 8+ 5x2+1 =43 

(0040) - 03 

b. (0041) - 04 
(0042) - 50 
(0043) - 29 
(0044) - 16 
(0045) - 83 

Ergebnis: Prüfsumme- 5x2+0 + 2x2 + 9 + 1 X2 + 6 + 8x2+3-50 

(0040) - 00 
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Flußdiagramm: 
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Quellprogramm: 


Objektprogramm: 


CHKDG 


SED 


;MACHE DIE GESAMTE ARITHMETIK 

LDX 

$41 

; DEZIMAL 

;INDEX- LÄNGE DER REIHE 

LDY 

#0 

;PRÜFSUMME- NULL 

LDA 

$41,X 

;HOLE NÄCHSTE ZWEI STELLEN DER 

LSR 

A 

; DATEN 

;VERSCHIEBE NIEDRIGSTWERTIGE STELLE 

LSR 

A 


LSR 

A 


LSR 

A 


STA 

$40 

;LÖSCHE ÜBERTRAG VON VERSCHIEBUNG 

CLC 


ADC 

$40 

;VERDOPPLE HÖCHSTWERTIGE STELLE 

STY 

$40 

;VERDOPPELN EINER ZIFFER ERZEUGT 

ADC 

$40 

; NIEMALS EINEN ÜBERTRAG 
;ADDIERE VERDOPPELTES MSD ZUR 

STA 

$40 

; PRÜFSUMME 

LDA 

$41.X 

;HOLE NIEDRIGSTWERTIGE STELLE 

AND 

#%00001111 

;(MASKIERE MSD AUS) 

CLC 


;ADDIERE LSD ZUR PRÜFSUMME 

ADC 

$40 


TAY 

DEX 

BNE 

CHKDG 

;SETZE FORT, BIS ALLE ZIFFERN SUMMIERT 

AND 

#%000011 1 1 

; SIND 

iBEWAHRE LSD DER SELBSTPRÜFENDEN 

STA 

$40 

; ZAHL AUF 

CLD 


;KEHREZUR BINÄREN BETRIEBSART 

BRK 


; ZURÜCK 


Speicher-Adresse 

(Hex) 

Speicher-Inhall 

(Hex) 

Befehl 

(Mnemonik) 

0000 

F8 

SED 


0001 

A6 

LDX 

$41 

0002 

41 



0003 

A0 

LDY 

#0 

0004 

00 



0005 

B5 

CHKDG LDA 

$41.X 

0006 

41 



0007 

4A 

LSR 

A 

0008 

4A 

LSR 

A 

0009 

4A 

LSR 

A 

000A 

4A 

LSR 

A 

000B 

85 

STA 

$40 

oooc 

40 



000D 

18 

CLC 


OODE 

65 

ADC 

$40 

000F 

40 



0010 

84 

STY 

$40 

0011 

40 



0012 

65 

ADC 

$40 

0013 

40 



0014 

85 

STA 

$40 

0015 

40 



0016 

B6 

LDA 

$41.X 

0017 

41 



0018 

29 

AND 

#%00001111 

0019 

OF 



001A 

18 

CLC 


0018 

65 

ADC 

$40 

001C 

40 



001D 

A8 

TAY 


001E 

CA 

DEX 


001F 

DO 

BNE 

CHKDG 

0020 

E4 



0021 

29 

AND 

#%0000 1111 

0022 

OF 



0023 

85 

STA 

$40 

0024 

40 



0025 

D8 

CLD 


0026 

00 

BRK 



Die Ziffern werden durch Verschieben und Maskieren entfernt. Vier logische 
Rechts-Verschiebungen sind erforderlich, um die höchstwertige Stelle zu sepa¬ 
rieren. 
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Die gesamte Arithmetik wird in dezimal ausgeführt. Erinnern Sie sich jedoch da 
ran, daß DEX weiterhin ein binäres Ergebnis liefert. 


Es gibt keine Probleme mit dem Übertrag vom Verdoppeln von Dezimalziffern, 
da das Ergebnis niemals größer als 18 sein kann. Sie können imstande sein, 
den letzten CLC-Befehl zu eliminieren, wenn Sie wissen, daß die zu summieren¬ 
den Zahlen zu klein sind, um jeweils einen Über rag zu erzeugen. 

Sie können eine Dezimalzahl im Akkumulator VERDOPPELN UND 

verdoppeln, indem sie diese zu sich selbst in der HALBIEREN VON 

dezimalen Betriebsart addieren. DEZIMALZAHLEN 

Eine typische Sequenz wäre folgende (Verwendung des Speicherplatzes 0040 
für Zwischenspeicherung): 


SED 


;MACHE ARITHMETIK DEZIMAL 

STA 

CLC 

$40 

iVERHINDERE, DASS ÜBERTRAG ADDITION 
: BEEINFLUSST 

ADC 

CLD 

$40 

VERDOPPLE ZAHL 

;KEHRE ZUR BINÄREN BETRIEBSART 


ZURUCK 


Sie können vielleicht die Befehle SED. CLC und CLD nicht benötigen, wenn an¬ 
dere Teile des Programmes die Flags für den Übertrag und die Dezimal- 
Betriebsart entsprechend setzen Beachten Sie, daß Sie nicht ASL A zum Ver¬ 
doppeln der Dezimalzahl verwenden können, da dieser Befehl ein binäres Er¬ 
gebnis liefert, auch wenn das Flag für die Dezimal Betriebsart gesetzt ist. 


Man kann eine Dezimalzahl durch 2 dividieren, indem man sie einfach nach 
rechts logisch verschiebt und dann 3 von jeder Stelle subtrahiert, die 8 oder 
größer ist (da 1 0 BCD gleich ist 16 binär). Das folgende Programm dividiert eine 
Dezimalzahl im Speicherplatz 0040 durch 2 und plaziert das Ergebnis in den 
Speicherplatz 0041: 


LDA $40 iHOLE DEZIMALZAHL 

LSR A ;DIVIDIERE DURCH 2 IN BINÄR 

TAX 

AND #%00001111 .IST DIE NIEDRIGSTWERTIGE STELLE 8 
ODER GROSSER? 

CMP #8 
BCC DONE 
TAX 

SBC #3 ;JA, SUBTRAHIERE 3 FÜR EINE DEZIMALE 

. KORREKTUR 

TAX 

DONE STX $41 .SPEICHERE DURCH 2 DIVIDIERTE ZAHL 

BRK 


Es gibt kein Problem mit dem Übertrag im SBC-Befehl, da dieser Befehl nur aus¬ 
geführt wird, wenn der Übertrag gesetzt ist. Erinnern Sie sich darßn, daß SBC 
vom komplementierten Übertrag (1 - C) subtrahiert, so daß ein Übertrag von 
1 niemals das Ergebnis beeinflußt. 
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Versuchen Sie dieses Programm und das Verfahren manuell an den Dezimal 
zahlen 28, 30 und 37. Haben Sie verstanden wie es arbeitet? 

Aufrunden ist sehr einfach, egal ob die Zahlen in binär oder BINÄRE 

dezimal vorliegen. Eine Binärzahl kann wie folgt aufgerun- AUFRUNDUNG 

det werden: L ————— 1 

Wenn das höchstwertige Bit, das zu unterdrücken ist, gleich 
1 ist, so addiere 1 zu den verbleibenden Bits. Andernfalls 
lasse die verbleibenden Bits unverändert. 

Diese Regel arbeitet, da 1 in der Mitte zwischen 0 und 10 in binär liegt, so wie 5 
in der Mitte bei Dezimalzahlen (Beachten Sie, daß 0.5 dezimale 0.1 binär). 

Daher wird das folgende Programm eine 16-Bit-Zahl in den Speicherplätzen 
0040 und 0041 (MSBs in 0041) auf eine 8-Bit-Zahl im Speicherplatz 0040 aufrun¬ 
den: 


LDA 

$40 

;IST DAS MSB DES EXTRABYTE 1 

BPL 

DONE 


INC 

$41 

:JA, RUNDE MSB'S AUF 

DONE BRK 




Wenn die Zahl größer ist als 1 6 Bits, muß die Aufrundung durch die anderen By¬ 
tes hindurch wenn nötig erfolgen. 

Beachten Sie. daß wir BIT $40 anstatt LDA $40 verwenden könnten, da der BIT- 
Befehl das Vorzeichen Flag entsprechend dem höchstwertigen Bit des adres¬ 
sierten Speicherplatzes setzt. Diese Lösung läßt den Akkumulator so wie er war, 
obwohl er die Statusflags ändert. 

Dezimale Aufrundung ist etwas schwierig, da der Über- DEZIMALE 

gangspunkt nun BCD 50 ist und die Autrundung ein dezi AUFRUNDUNG 

males Ergebnis liefern muß. ~ — ~~ 1 

Die Regel lautet: 

Wenn die höchstwertige Ziffer, die zu unterdrücken ist, 
gleich 5 oder größer ist, addiere 1 zu den verbleibenden 
Stellen. 

Das folgende Programm wird eine vierstellige BCD-Zahl in den Speicherplätzen 
0040 und 0041 (MSDs in 0041) auf eine zweistellige BCD-Zahl im Speicherplatz 
0041 aufrunden: 

LDA $40 ;IST DAS ZU UNTERDRÜCKENDE BYTE 50 

; ODER MEHR? 

CMP #$50 
BCC DONE 

SED ;JA RUNDE MSDS UM 1 IN DEZIMAL 

; AUF 

LDA $41 

ADC # 0 ;ADDlERE IN ÜBERTRAG (ZU SETZEN) 

STA $41 

CLD ;KEHREZU BINÄR-BETRIEBSARTZURÜCK 

DONE BRK 

Erinnern Sie sich daran, daß Sie den INC-Befehl nicht zur Addition von 1 ver¬ 
wenden können, da dieser Befehl immer ein binäres Ergebnis liefert Der Befehl 
ADC #0 wird 1 zum Akkumulator addieren, da der Übertrag 1 vor der Ausfüh¬ 
rung des Befehles gesetzt werden muß (andernfalls würde der BCC-Betehl eine 
Verzweigung erzwungen haben). Wie gewöhnlich müssen Sie sehr sorgfältig 
das Flag für die Dezimai-Bertriebsart entsprechend setzen. Für größere Zahlen 
muß die Aufrundung durch die höchstwertigen Bits entsprechend fortgesetzt 
werden. 
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AUFGABEN: 

1) Binäre Subtraktion mit mehrfacher Genauigkeit 

Zweck: Subtrahiere eine Mehrwort-Zahl von einer anderen. Die Länge der Zah¬ 
len befindet sich im Speicherplatz 0040, die Zahlen selbst beginnen 
(höchstwertige Bits zuerst) in den Speicherplätzen 0041 und 0051, und 
die Differenz ersetzt die Zahl, die im Speicherplatz 0041 beginnt. Sub¬ 
trahiere die Zahl, die in 0051 beginnt von der Zahl, die in 0041 beginnt 

Beispiel: 

(0040) - 04 

(0041) - 2F 
(0042) - 5B 
(0043) - A7 
(0044) - C3 

(0051) - 14 
(0052) - DF 
(0053) - 35 
(0054) - B8 

Ergebnis: (0041) - 1A 

(0042) - 7C 
(0043) - 72 
(0044) - OB 

das heißt: 2F5BA7C3 

-14DF35B8 
1A7C720B 


2) Dezimale Subtraktion 

Zweck: Subtrahiere eine Mehrwon: Dezimalzahl (BCD) von einer anderen. Die 
Länge der Zahlen befindet sich in Speicherplatz 0040, die Zahlen 
selbst starten (höchstwertige Bits zuerst) entsprechend in den Spei¬ 
cherplätzen 0041 und 0051, und die Differenz ersetzt die Zahl, die im 
Speicherplatz 0041 beginnt. Subtrahiere die Zahl, die in 0051 beginnt, 
von der Zahl die in 0041 beginnt. 
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Beispiel: 


(0040) - 04 

(0041) - 36 
(0042) - 70 
(0043) - 19 
(0044) - 85 

(0051) - 12 
(0052) - 66 
(0053) - 34 
(0054) - 59 

Ergebnis: (0041) - 24 

(0042) - 03 
(0043) - 85 
(0044) - 26 

das heißt: 36701985 

-12663459 
24038526 


3) Binär-Multiplikation 8 Bit mal 16 Bit 

Zweck: Multipliziere die 16-Bit-Zahl ohne Vorzeichen in den Speicherplätzen 
0040 und 0041 (höchstwertige Bits in 0041) mit der 8 Bit-Zahl ohne Vor¬ 
zeichen im Speicherplatz 0042. Speichere das Ergebnis in die Spei¬ 
cherplätze 0043 bis 0045, mit den höchstwertigen Bits im Speicherplatz 
0045. 

Beispiele: 


a. 

(0040) 

- 

03 



(0041) 

- 

00 



(0042) 


05 


Ergebnis: 

(0043) 


0F 



(0044) 

- 

00 



(0045) 


00 


das heißt: 

3x5- 

15 



b. 

(0040) 


6F 



(0041) 

- 

72 

(29 295 dezimal) 


(0042) 


61 

(97 dezimal) 

Ergebnis: 

(0043) 


0F 



(0044) 

- 

5C 



(0045) 

- 

2B 


das heißt: 

29 295 X 97 

= 2841 615 
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4) Binäre Division mit Vorzeichen 


Beispiele: 


Zweck: Dividiere die 16-Bit-Binärzahl mit Vorzeichen in den Speicherplät¬ 
zen 0040 und 0041 (höchstwertige Bits in 0041) durch die 8-Bit- 
Zahl mit Vorzeichen im Speicherplatz 0042, Die Zahlen sind nomi¬ 
niert, so daß die Größe des Speicherplatzes 0042 größer als die 
Größe des Speicherplatzes 0041 ist. Speichere den Quotienten (mit 
Vorzeichen) in den Speicherplatz 0043 und den Rest (immer posi¬ 
tiv) in den Speicherplatz 0044. 


a. (0041) - 03 

(0042) - 36 
(0043) - 68 
(0044) _ 51 

Ergebnis: Prüfsumme 3+3x6+7x6+8+3 

(0040) - 03 


Beispiele: 


a. 

(0040) 

- 

CO 



(0041) 

= 

FF 

(-64) 


(0042) 

= 

08 


Ergebnis: 

(0043) 

= 

F8 

(-8) Quotient 


(0044) 

= 

00 

(0) Rest 

b. 

(0040) 

* 

93 



(0041) 


ED 

(-4717) 


(0042) 

- 

47 

(71 dezimal) 

Ergebnis: 

(0043) 

_ 

BD 

(-67 dezimal) 


(0044) 

- 

28 

(+40 dezimal) 


(0041) - 04 
(0042) - 50 
(0043) - 29 
(0044) - 16 
(0045) - 83 

Ergebnis: Prüfsumme- 5 + 3x0 + 7 x2 + 9+ 3 

+ 3 x 3 - 90 
(0040) - 00 

Hinweis: Beachten Sie bitte, daß 7 - 2 x 3 + 1 und 3 - 2 
mel Mj - 2 x Mj -1 + 1 verwendet werden kann, um den 
faktor zu berechnen. 


Hinweis: Bestimme das Vorzeichen des Ergebnisses, führe eine Division ohne 
Vorzeichen aus, und korrigiere den Quotienten und den Rest entsprechend. 


5) Selbstprüfende Zahlen (Aligned 1,3, 7 Mod 10) 

Zweck: Berechne eine Prüfsummen-Zitfer aus einer Reihe von BCD-Ziffern, 
Die Länge der Reihe der Ziffern (Anzahl der Worte) befindet sich im 
Speicherplatz 0041. Die Ziffernreihe (2 BCD-Stellen in einem Woit) 
beginnt im Speicherplatz 0042. Berechne die Prüfsummen-Ziffer mit 
dem Verfahren "Aligned 1. 3. 7 Mod 10" und speichere sie in den 
Speicherplatz 0040. 

Das Verfahren "Aligned 1. 3, 7 Mod 10" arbeitet wie folgt: 

1) Lösche zu Beginn die Prüfsumme 

2) Addiere die führende Stelle zur Prüfsumme. 

3) Multipliziere die nächste Stelle mit 3 und addiere das Ergebnis zur 

Prüfsumme. 

4) Multipliziere die nächste Stelle mit 7 und addiere das Ergebnis zur 

Prüfsumme. 

5) Setze das Verfahren fort (Sch ritt 2 bis 4) bis alle Stellen verwendet wurden. 

6) Die selbstprüfende Ziffer ist die niedrigstwertige Stelle der Prüfsumme, 

Beispielsweise, wenn die Ziffernreihe 

549321 


lautet, wird das Ergebnis sein: 

Prüfsumme - 5 + 3x4 + 7x9 + 3+ 3x2 + 7x1-96 
Selbstprüfende Ziffer-6 


x 5 + 7 x 1 -93 


x 1 + 7 x 6 +8 


! x 1 + 1, so daß die For 
nächsten Multiplikations 
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Kapitel 9 

TABELLEN UND LISTEN 

Tabellen und Listen sind zwei der grundlegenden Datenstrukturen, d ie bei al¬ 
len Computern verwendet werden. Wir haben bereits Tabellen gesehen, die 
zur Ausführung von Code-Umwandlungen und arithmetischen Aufgaben einge¬ 
setzt wurden. Tabellen können auch zur Identifizierung und Ausführung von 
Kommandos und Befehlen, zur Linearisierung von Daten, für den Zugriff auf 
Dateien oder Aufzeichnungen, Definition der Bedeutung von Tasten oder 
Schaltern und zur Auswahl verschiedener Programme verwendet werden. Li¬ 
sten sind gewöhnlich weniger strukturiert als Tabellen. Listen können Aufga¬ 
ben enthalten, die der Prozessor ausführen muß, Nachrichten oder Daten, die 
der Prozessor aufzeichnen muß, oder Bedingungen, die sich geändert haben 
oder überwacht werden sollten. Tabellen sind ein einfaches Hilfsmittel für das 
Fällen von Entscheidungen oder Lösung von Aufgaben, da keine Berechnun¬ 
gen oder logische Funktionen erforderlich sind. Die Aufgabe wird dann auf die 
Organisation der Tabelle reduziert, damit die entsprechende Eingabe leicht zu 
finden ist. Listen gestatten die Ausführung von Sequenzen von Aufgaben, die 
Vorbereitung mehrerer Resultate und den Aufbau voneinander abhängiger Da¬ 
teien (oder Daten-Basen). Die Aufgaben beinhalten auch etwa das Hinzufügen 
von Elementen zu einer Liste oder die Entfernung von Elementen hiervon. 


A. J. Weissberger and T. Toal. "Tough Mathematical Tasks Are Child's Play 
for Number Cruncher," Electronics February 17, 1977, pp. 102-107. 
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BEISPIELE 

Hinzufügen einer Eingabe zu einer Liste 

Zweck: Addiere den Inhalt des Speicherplatzes 0040 zu einer Liste, wenn er 
noch nicht in der Liste vorliegt. Die Länge der Liste befindet sich im 
Speicherplatz 0041 und die Liste selbst beginnt im Speicherplatz 0042. 

Beispiele: 

a. (0040) - 6B 

(0041) = 04 
(0042) - 37 
(0043) «= 61 
(0044) - 38 
(0045) - ID 

Ergebnis: (0041) ^ 05 

(0046) - 6B 

Die Eingabe (6B) wird zur Liste hinzugefijgt, da sie noch nicht voriiegt. Die Län- 

Liste wird um 1 erhöht. 

b. (0040) = 6B 

(0041) - 04 
(0042) = 37 
(0043) - 6B 
(0044) = 38 

(0045) = 1D 

Ergebnis: Keine Änderung, da die Eingabe (6B) bereits in der Liste (im 

Speicherplatz 0043) vorhanden ist. 
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Flußdiagramm: 



Quellprogramm: 


LDA $40 
LDX $41 

SRLST CMP $41,X 
BEO DONE 


BNE SRLST 
INC $41 
LDX $41 
STA $41 ,X 
DONE BRK 


;HOLE EINGABE 

;INDEX = LÄNGE DER LISTE 

;IST EINGABE» ELEMENT IN LISTE? 

;JA, ZU DONE 

;NEIN, GEHE ZU NÄCHSTEM ELEMENT 
; WEITER 

;ADDIERE 1 ZUR LISTENLÄNGE 
;ADDIERE EINGABEZUR LISTE 
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Objektprogramm: 



Diese Methode der Addition von Elementen ist offensicht¬ 
lich sehr ineffizient, wenn die Liste lang ist. Wir könnten das 


HASHING 


Verfahren verbessern, indem wir das Suchen auf einen Teil der Liste beschrän¬ 


ken oder die Liste entsprechend anordnen. Wir könnten das Suchen auch be¬ 
grenzen, indem wir die Eingabe verwenden, um einen Startpunkt in der Liste 
zu erhalten. Dieses Verfahren wird "Hashing" (deutsch etwa "Zerhacken") ge¬ 
nannt und ähnelt sehr der Auswahl einer "Startseite" in einem Wörterbuch oder 


Telefonbuch mit dem ersten Buchstaben einer Eingabe. Wir könnten die Liste 
nach numerischen Werten anordnen Der Suchvorgang sollte dann enden, wenn 
die Listenwerte unter der Eingabe liegen (größer oder kleiner, abhängig von der 
verwendeten Ordnungstechnik). Eine neue Eingabe müßte entsprechend einge¬ 
setzt werden, und alle anderen Eingaben müßten in der Liste nach unten ver¬ 
schoben werden. 


Das Programm könnte so umgebaut werden, daß zwei Tabellen verwendet wer¬ 
den. Eine Tabelle könnte einen Startpunkt in der anderen Tabelle liefern. Zum 
Beispiel könnte der Suchpunkt auf der höchst- oder niedrigstwertigen 4-Bit-Zif- 
fer in der Eingabe basieren. 

Das Programm arbeitet nicht, wenn die Länge der Liste null wäre (was ge¬ 
schieht?). Wir können dieses Problem vermeiden, indem wir anfangs die Länge 
der Liste prüfen. Der Initialisierungs-Vorgang wäre dann 

LDX $41 ;INDEX-LÄNGE DER LISTE 

BEQ ADELM ;ADDIERE EINGABE ZUR LISTE, WENN DIE 

; LÄNGE NULL IST 


ADELM INC $41 ;ADDIERE 1 ZUR LÄNGE 
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Anders als bei einigen anderen Prozessoren wird das Nuii-Fiag des 6502 durch 
Transfer-Befehle wie Laden und Speichern beeinflußt. 

Wenn |ede Eingabe länger ais ein Wort wäre, so wäre ein Programm erforder¬ 
lich, das die Bitmuster in Übereinstimmung bringt. Das Programm müßte zur 
nächsten Eingabe weitergehen, wenn keine Übereinstimmung auftritt, d h. über 
den letzten Teil der momentanen Eingabe springen, sobald eine Nicht-Überein¬ 
stimmung gefunden wurde 


Prüfen einer geordneten Liste 

Zweck: Prüfe den Inhalt des Speicherplatzes 0041 um festzustellen, ob dieser 
Wert in einer geordneten Liste liegt. Die Länge der Liste liegt im Spei¬ 
cherplatz 0042, die Liste selbst beginnt im Speicherplatz 0043 und 
besteht aus Binärzahlen ohne Vorzeichen in steigender Reihenfolge. 
Wenn der Inhalt des Speicherplatzes 0041 in der Liste liegt, lösche 
Speicherplatz 0040. Andernfalls setze Speicherplatz 0040 auf FFi«. 

Beispiele: 

a. (0041) - 6B 

(0042) - 04 
(0043) - 37 
(0044) - 55 
(0045) - 7D 
(0046) - AI 

Ergebnis: (0040) - FF, da sich 6B nicht in der Liste befindet. 

b. (0041) - 6B 

(0042) - 04 
(0043) - 37 
(0044) - 55 
(0045) - 6B 
(0046) - AI 

Ergebnis: (0040) - 00, da sich 6B in der Liste befindet. 
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Das Suchverfahren ist ein wenig anders, da hier die Elemente geordnet sind. 
Sobald wir ein Element linden, das kleiner ist als die Eingabe (en nnern Sie sich 
daran, daß wir uns rückwärts durch die Liste in der gebräuchlichen Art und Wei¬ 
se des 6502 bewegen), das Suchen vorüber ist, da weiter folgende Elemente 
noch kleiner sein werden. Sie könnten vielleicht ein Beispiel versuchen, um 
sich zu überzeugen, daß dieses Verfahren arbeitet. Beachten Sie, daß ein Ele¬ 
ment kleiner ajs die Eingabe durch einen Vergleich angezeigt wird, der kein 
"Borgen" (d.h. Übertrag - 1) erzeugt. 

Wie bei der vorhergehenden Aufgabe könnte eine Tabelle SUCH- 
oder ein anderes Verfahren einen guten Star punkt wählen, METHODEN 
um das Suchen zu beschleunigen. Ein Verfahren bestünde 
im Starten In der Mitte und Im Bestimmen, in welcher Hälfte der Liste die Ein¬ 
gabe war, dann die Hälfte In Hälften zu teilen etc. Dieses Verfahren wird binä¬ 
res Suchen benannt, da es den verbleibenden Rest jedesmal in die Hälfte 
teilt.' 
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Quellprogramm: 


LDA $41 ;HOLE EINGABE 

LDX $42 ;INDEX-LÄNGE DER LISTE 

LDY #0 :MARKE-NULL FÜR ELEMENT IN LISTE 

SRLST CMP $42,X ;IST EINGABE GLEICH MIT ELEMENT? 

BEO DONE ;JA, SUCHEN ABGESCHLOSSEN 

BCS NOTIN EINGA BE NICHT IN LISTE, WENN 

; GROSSER ALS ELEMENT 

DEX 

BNE SRLST 

NOTIN LDY #$FF ;MARKE - FF FÜR NICHT IN DER LISTE 

DONE STY $40 ;BEWAHRE MARKE AUF 

BRK 


Objektprogramm: 



Dieser Algorithmus ist ein wenig langsamer, als jener in dem Beispiel, das in 
''Hinzufügen einer Eingabe zu einer Liste" angegeben wurde, infolge des zu¬ 
sätzlichen bedingten Sprunges (BCS NOTIN). Die durchschnittliche Ausfüh¬ 
rungszeit für dieses einfache Suchverfahren steigt linear mit der Länge der Liste 
an, während die durchschnittliche Ausführungszeit für einen binären Suchvor¬ 
gang logarithmisch ansteigt Wenn zum Beispiel die Länge der Liste doppelt so 
groß ist, so benötigt das einfache Verfahren doppelt so lang wie der Durch¬ 
schnitt, während das binäle Suchen nur eine zusätzliche Wiederholung erfor¬ 
dert. 


9-7 









Entfernen eines Elementes von einer Warteschlange 

Zweck: Die Speicherplätze 0042 und 0043 enthalten die Adresse der Spitze 
(Kopf) der Warteschlange (MSBs in 0043). Plaziere die Adresse des er¬ 
sten Elementes (Kopf) der Warteschlange in die Speicherplätze 0040 
und 0041 (MSBs in 0041) und bringe die Warteschlange auf den neue¬ 
sten Stand, um das Element zu entfernen. Jedes Element in der Schlan¬ 
ge ist zwei Bytes lang und enthält die Adresse des nächsten 2-Byte-Eie- 
mentes in der Schlange. Das letzte Element in der Warteschlange ent¬ 
hält null, um anzuzeigen, daß es kein weiteres Element gibt. 

Warteschlangen werden zum Speichern von Daten in der Reihenfolge verwen¬ 
det, in der sie gebraucht werden, oder für Aufgaben in der Reihenfolge, in der 
sie ausgeführt werden. Die Warteschlange besitzt eine "Zuerst-ein-, Zuerst- 
aus-’-Datenstrvktur, d.h. Elemente werden von der Warteschlange in der glei¬ 
chen Reihenfolge entfernt, in der sie eingegeben wurden. Betriebs-Systeme 
plazieren Aufgaben in Warteschlangen, so daß sie in der entsprechenden Rei¬ 
henfolge ausgeführt werden. E/A-Treiber transferieren Daten zu oder von Warte¬ 
schlangen, so daß sie übertragen oder in der entsprechenden Reihenfolge ver¬ 
arbeitet werden. Puffer können ebenfalls in Warteschlangen angeordnet werden, 
so daß der nächste verfügbare Puffer leicht gefunden werden kann, und jene, 
die ausgegeben wurden, leicht zum jeweils verfügbaren Speicher hinzugefügt 
werden können. War eschlangen können auch zur Aneinander-Reihung von An¬ 
forderungen für Speicherung, zeitliche Steuerung oder E/A verwendet werden, 
so daß diese in der korrekten Reihenfolge befriedigt werden können. 

In realen Anwendungen wird jedes Element in der Warteschlange typisch eine 
große Anzahl von Informationen oder Speicherraum neben den erforderlichen 
Adressen enthalten, damit ein Element mit dem nächsten verbunden werden 
kann. 

Beispiele: 

a. (0042) - 46 1 Adresse des ersten Elementes 

(0043) - 00 / in der Warteschlange 
(0046) - 4D \ Adresse des zweiten Elementes 
(0047) - 00 l in der Warteschlange 

(004E) - SS/ Endeder Warteschlange 

Ergebnis: (0040) - 46 1 Adresse des aus der Warteschlange 

(0041) - 00 / entfernten Elementes 
(0042) - 4D \ Adresse des neuen ersten 
(0043) - 00 / Elementes in der Warteschlange 

b ' ( 0043 *) I 00 } Leere Warteschlange 

Ergebnis: (0040) - 00 1 Kein Element von der 

(0041) - 00 / Warteschlange verfügbar 
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Flußdiagramm: 


Quellprogramm: 



LDA $42 
STA $40 
LDA $43 
STA $41 
ORA $42 
BEO DONE 
LDY #0 

LDA ($40),Y 
STA $42 
INY 

LDA ($40),Y 
STA $43 
DONE BRK 


iENTFERNE KOPF VON WARTESCHLANGE 


IST WARTESCHLANGE LEER? 

JA. DONE 

NEIN, BRINGE NÄCHSTES ELEMENT ZUM 
KOPF DER WARTESCHLANGE 


9-9 






Objektprogramm: 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) 

0000 

A5 

LDA 

$42 

0001 

42 



0002 

85 

STA 

$40 

0003 

40 



0004 

A5 

LDA 

$43 

0005 

43 



0006 

85 

STA 

$41 

0007 

41 



0008 

05 

ORA 

$42 

0009 

42 



O00A 

F0 

BEO 

DONE 

0008 

OB 



oooc 

A0 

LDY 

#0 

000D 

00 



000E 

81 

LDA 

($40). Y 

000F 

40 



0010 

85 

STA 

$42 

0011 

42 



0012 

C8 

INY 


0013 

81 

LDA 

($40).Y 

0014 

40 



0015 

85 

STA 

$43 

0016 

43 



0017 

00 DONE 

BRK 



Mit dem Anordnen in Warteschlangen kann man Listen verarbeiten, die sich 
nicht in aufeinanderfolgenden Speicherplätzen befinden. Jedes Element in der 
Warteschlange muß die Adresse des nächsten Elementes enthalten. Derartige 
Listen gestatten Ihnen, Daten oder Aufgaben in der entsprechenden Reihenfol¬ 
ge zu verarbeiten, Variable zu ändern oder Definitionen in ein Programm einzu¬ 
fügen. Hiedür ist zusätzlicher Speicherplatz erforderlich, jedoch können die Ge¬ 
mente leicht hinzugefügt oder entfernt werden. 

Nach-indizieite oder indirekte indizierte Adressierung ist hier sehr handlich, da 
es uns gestattet, den Inhalt der Speicherplätze 0040 und 0041 als Zeiger zu ver¬ 
wenden. Diese Speicherplätze enthalten die Adresse des Kopfes der Warte¬ 
schlange, der wiederum die Adresse des nächsten Elementes enthält. Die Spei¬ 
cherplätze. in welchen die Adresse des Elementes gespeichert ist. muß auf Sei¬ 
te null sein, da sie mit nach-indizierter Adressierung verwendet werden. Alle 
anderen Adressen können irgendwo im Speicher liegen Die nach-indizierte 
Adressierung könnte ebenfalls später verwendet werden, um Daten zu oder von 
dem Element zu transferieren, das eben von der Warteschlange entfernt worden 
ist 


Erinnern Sie sich daran, daß Nach-Indizierung nur für Adressen auf der Nullseite 
verfügbar ist. Ferner kann nur das Indexregister V in dieser Betriebsart verwen¬ 
det werden. 

Beachten Sie die Verwendung der Sequenz 

LDA $43 
ORA $42 

zur Bestimmung, ob die 16-Bit-Zahl in den Speicherplätzen 0042 und 0043 
gleich null ist. Versuchen Sie einige andere Sequenzen zu finden, die diese Auf¬ 
gabe handhaben könnten - es tritt offensichtlich auf, wann immer Sie einen 
16-Bit-Zähler ansfaff des 0-Bit-Zählers einsetzen. den wir in den meisten der 
Beispiele verwendet haben. 

Ein Problem mit dem Befehlssatz des 6502 besteht darin, daß er keine Befehle 
hat, die speziell 16-Bit Adressen (oder Daten) von einer Stelle zu einer anderen 
transferieren oder andere 16-Bit-Operationen ausführen können. Natürlich müß¬ 
ten derartige Befehle jeweils 8 Bits gleichzeitig bearbeiten, es könnten jedoch 
etliche Zyklen für das Holen und Decodieren des Befehls eingespait werden. 
Die meisten übrigen Mikroprozessoren besitzen derartige Befehle. 

Es kann sehr nützlich sein, Zeiger an beiden Enden der Warteschlange einzu¬ 
richten, anstatt nur an deren Kopf . 2 ' 3 Die Datenstruktur kann dann entweder in 
einer "Zuerst-ein-, Zuerst-aus”-Weise oder in einer "Zuletzt-ein-, Zuerst-aus”- 
Weise verwendet werden, abhängig davon, ob neue Elemente zum Kopf oder 
zum Schwanz der Warteschlange hinzugefügt werden. Wie würden Sie das 
Programmbeispiel ändern, damit die Speicherplätze 0044 und 0045 die Adresse 
des letzten Elementes (Schwanz) der Warteschlange enthalten? 

Wenn es keine Elemente in der Warteschlange gibt, so löscht das Programm die 
Speicherplätze 0040 und 0041. Ein Programm, das ein Element aus der Warte¬ 
schlange anfordert, würde dann diese Speicherplätze zu prüfen haben, um fest¬ 
zustellen, ob die Anfrage erledigt wurde. Können Sie sich andere Arten vorstel¬ 
len, mit denen diese Information zu erhalten ist? 


8-Bit-Sortierung 

Zweck: Sortiere eine Anordnung von Binärzahlen ohne Vorzeichen in abneh¬ 
mender Reihenfolge. Die Länge der Anordnung liegt im Speicherplatz 
0040, und die Anordnung selbst beginnt im Speicherplatz 0041. 

Beispiel: 

(0040) - 06 
(0041) _ 2A 
(0042) - B5 
(0043) - 60 

(0044) - 3F ' 

(0045) - Dl 
(0046) - 19 

Ergebnis: (0041) - Dl 

(0042) - B5 
(0043) - 60 
(0044) - 3F 
(0045) - 2A 
(0046) - 19 
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Eine einfache Sortier-Technik arbeitet folgender¬ 
maßen: 


Schrill 1) Lösche ein Flag INTER 

Schritt 2) Prüfe jedes aufeinanderfolgende Paar von Zahlen in der Anord¬ 
nung. Wenn sich hiervon welche nicht in der Reihenfolge befin¬ 
den. tausche sie aus und setze INTER. 

Schritt 3) Wenn INTER - 1. nachdem die gesamte Anordnung geprüft wurde, 
gehe zu Schritt 1 zurück. 

INTER wird gesetzt, wenn irgendein aufeinanderfolgendes Paar von Zahlen 
nicht in der Reihenfolge liegt. Daher befindet sich, wenn INTER = 0 am Ende 
eines Durchlaufes durch die gesamte Anordnung, diese Anordnung in der rich¬ 
tigen Reihenfolge. 

Dieses Sortier-Verfahren wird als "Bubble sort” (deutsch etwa "stu¬ 
fenweise Sortierung”) bezeichnet. Der Algorithmus ist leicht auszuführen. Es 
sollten jedoch andere Sortier-Verfahren untersucht werden, wenn lange Listen 
zu sortieren sind und die Geschwindigkeit von Bedeutung ist . 1 ' 4 ' 9 

Diese Technik arbeitet in einem einfachen Fall wie folgt. Nehmen 
wir an, daß wir eine Reihe in abnehmender Reihenfolge sortieren 
wollen. Die Reihe besitzt vier Elemente - 12, 03, 15, 08, Wir wollen 
uns rückwärts durch die Anordnung arbeiten, wie es für den 6502 
üblich ist. 

Erste Wiederholung: 

Schritt 1) INTER =0 

Schritt 2) Abschließende Reihenfolge der Reihe ist: 

15 

12 

03 

08 

da das zweite Paar (03, 15) ausgelauscht wurde und ebenso das 
dritte Paar (12, 15). 

INTER= 1 

Zweite Wiederholung: 

Schritt 1) INTER= 0 

Schritt 2) Abschließende Anordnung dieser Reihe ist: 

15 

12 

08 

03 

da das erste Paar (08, 03) ausgetauscht wurde. INTER = 1. 


EINFACHER 

SORTIER¬ 

ALGORITHMUS 


Dritte Wiederholung: 

Schritt 1) INTER-0 

Schritt 2) die Elemente befinden sich bereits in der richtigen Reihenfolge, so 
daß kerne Vertauschungen erforderlich sind und INTER gleich null 
bleibt. 

Beachten Sie, daß immer eine zusätzliche Wiederholung ausgeführt wird um 
festzustellen, daß die Elemente in der richtigen Reihenfolge liegen. Hier sind 
offensichtlich noch zahlreiche Verbesserungen möglich, und neue Sortierver¬ 
fahren werden laufend eingehend untersucht. 

Flußdiagramm: 
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Quellprogramm: 


SORT 

LDY 

#0 

AUSTAUSCH-FLAG =0 


LDX 

$40 

HOLE LÄNGE DER ANORDNUNG 


DEX 


ORDNE REIHENLÄNGE IN ANZAHL DER 




PAARE 

PASS 

LDA 

$40.X 

IST DAS PAAR DER ELEMENTE IN DER 




REIHENFOLGE? 


CMP 

$41,X 



BCS 

COUNT 

JA. VERSUCHE NÄCHSTES PAAR 


LDY 

#1 

NEIN. SETZE AUSTAUSCH-FLAG 


PHA 


TAUSCHE ELEMENTE UNTER 




VERWENDUNG DES STAPELS AUS 


LDA 

$41,X 



STA 

$40,X 



PLA 




STA 

$41,X 


COUNT 

DEX 

;PRÜFE AUF VOLLSTÄNDIGEN DURCHLAUF 


BNE 

PASS 



DEY 


WAREN ALLE ELEMENTE IN DER 




REIHENFOLGE? 


BEO 

SORT 

NEIN, GEHE WIEDER DURCH DIE REIHE 


BRK 




Objektprogramm: 


Speicher Adresse 
(Hex) 

Speicher-Inhalt 

(Hex) 


Befehl 

(Mnemonik) 

0000 

A0 

SORT 

LDY 

#0 

0001 

00 




0002 

A6 


LDX 

$40 

0003 

40 




0004 

CA 


DEX 


0005 

85 

PASS 

LDA 

$40.X 

0006 

40 




0007 

D5 


CMP 

$41,X 

0008 

41 




0009 

B0 


BCS 

COUNT 

000A 

0A 




0008 

A0 


LDY 

#1 

oooc 

01 




000D 

48 


PHA 


OOOE 

85 


LDA 

$4 1.X 

OOOF 

41 




0010 

95 


STA 

$40.X 

0011 

40 




0012 

68 


PLA 


0013 

95 


STA 

$41,X 

0014 

41 




0015 

CA 

COUNT 

OEX 


0016 

DO 


BNE 

PASS 

0017 

ED 




0018 

88 


DEY 


0019 

F0 


BEQ 

SORT 

001A 

E5 




0018 

00 


BRK 



Der Fall, bei dem zwei Elemente in der Anordnung gleich sind, ist sehr wichtig. 
Das Programm sollte einen Austausch in diesem Fall nicht ausführen, da die¬ 
ser Austausch bei jedem Durchlauf erfolgen würde. Das Ergebnis wäre, daß je¬ 
der Durchlauf das Austauschflag setzen würde, und damit eine endlose Schlei¬ 
fe zur Folge hätte. Das Programm vergleicht die Elemente in der spezifizierten 
Reihenfolge, so daß das Übertrags-Flag gesetzt wird, wenn die Elemente bereits 
korrekt angeordnet sind. Erinnern Sie sich daran, daß der Vergleich zweier glei¬ 
cher Werte das Übertrags-Flag setzt, da das Flag ein invertiertes "Borgen" nach 
Subtraklionen oder Vergleichen ist. 

Die Befehle für bedingte Verzweigungen des 6502 haben ihre Grenzen und spe¬ 
ziell in diesem Programm. Folgen wir einem Befehl wie CMP, so haben wir nur 
BCC, eine Verzweigung wenn (M) > (A), und BCS, verzweige wenn (M) ^ (A). 
Der 6502 besitzt keine Verzweigungsbefehle für die Fälle, bei denen die Gleich¬ 
heits-Bedingung auf der anderen Seite liegt, d.h.: (M) > (A) und (M) $ (A). Des¬ 
halb müssen wir die Reihenfolge der Operationen sehr sorgfältig beachten. 

Vor dem Starten jedes Sortier-Durchlaufes müssen wir darauf achten, den Index 
und das Austausch Flag zu initialisieren. 

Das Programm muß den Zähler um 1 zu Anfang reduzieren, da die Anzahl der 
aufeinander folgenden Paare um 1 kleiner ist als die Anzahl der Elemente (dem 
letzten Element folgt kein weiteres). 

Dieses Programm arbeitet nicht ordnungsgemäß, wenn es weniger als zwei Ele¬ 
mente in der Anordnung gibt. Wie können Sie diesen Fall handhaben? 


Es gibt zahlreiche Sortier-Algorithmen, die sich in 
ihrer Effizienz sehr weitgehend unterscheiden 
Die Literatur 1. 4 und 5 beschreiben einige hier¬ 
von. 

Der Stapel ist sehr leicht für zeitweilige Speicherung in diesem Programm zu 
verwenden, da die Befehle PHA (Push Accumulator oder Store Accumulator in 
Stack) und PLA (Pull Accumulator oder Load Accumulator from Stack) nur je¬ 
weils ein Byte lang sind. Die Adresse liegt im Stapelzeiger (erweitert mit 01 wie 
seine Seitennummer). Wenn Sie wollen, können Sie einen festen Speicherplatz 
ersetzen, wie etwaOOSF. Der Austausch ist dann: 

STA $3F JAUSCHE ELEMENTE UNTER VERWEN- 

; DUNG EINER ZWISCHENSPEICHERUNG 
AUS 

LDA $41,X 
STA $40,X 
LDA $3F 
STA $41,X 

Siehe Kapitel 10 für eine weitere Besprechung des RAM-Stapels des 6502. 


ANDERE SORTIER¬ 
VERFAHREN 
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Verwendung einer geordneten Sprungtabelle 

Zweck: Verwende den Inhalt des Speicherplatzes 0042 als einen Index zu einer 
Sprungtabelle, beginnend im Speicherplatz 0043. Jede Eingabe in die 
Sprungtabelle enthält eine 16-Bit Adresse mit den LSBs im ersten Byte. 
Das Programm sollte die Steuerung zu der Adresse mit dem entspre¬ 
chenden Index transferieren, d.h wenn der Index 6 ist, springt das Pro¬ 
gramm zur Adressen-Eingabe Nr. 6 in der Tabelle. Nimm an, daß die 
Tabelle weniger als 128 Eingaben besitzt. 


Beispiel: 

(0042) = 02 
(0043) = 4C 
(0044) = 00 
(0045) - 50 
(0046) = 00 
(0047) = 54 
(0048) = 00 
(0049) = 58 
(004A) = 00 


Index für Sprungtabelle 
nulltes Element in Sprungtabelle 

erstes Element in Sprungtabelle 

zweites Element in Sprungtabelle 

drittes Element in Sprungtabelle 


Objektprogramm: 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) 

0000 

A5 

LDA 

$42 

0001 

42 



0002 

OA 

ASL 

A 

0003 

AA 

TAX 


0004 

B5 

LDA 

$43.X 

0005 

43 



0006 

85 

STA 

$40 

0007 

40 



0008 

85 

LDA 

$44.X 

0009 

44 



OOOA 

85 

STA 

$41 

000B 

41 



oooc 

6C 

JMP 

($401 

000D 

40 



000E 

00 




Ergebnis: (PC) = 0054 .da dies die Eingabe Nr 2 (beginnend bei 

null) in die Sprungtabelle ist. Der nächste 
auszuführende Befehl wird der eine sein, 
der an dieser Stelle liegt. 

Flußdiagramm: 



QueJIprogramm: 


LDA 

$42 

;HOLE INDEX 

ASL 

TAX 

A 

VERDOPPLE INDEX FÜR 2-BYTE-TABELLE 

LDA 

$43,X 

;HOLE LSB’S DER SPRUNGADRESSE 

STA 

$40 


LDA 

$44,X 

;HOLE MSB’S DER SPRUNGADRESSE 

STA 

$41 


JMP 

($40) 

;TRANSFERIERE STEUERUNG ZU 
; BESTIMMUNGSORT 


Das letzte Kästchen resultiert in einem Transfer der Steuerung zur Adresse, die 
aus der Tabelle erhalten wird. 


Sprungtabeilen sind in Situationen sehr nützlich, In denen eine von mehreren 
Routinen ausgewählt werden muß. Deraitlge Situationen treten beim Decodie¬ 
ren von Kommandos (beispielsweise eingegeben von einer Tastatur), Auswahl 
von Testprogrammen, Wahl unterschiedlicher Methoden oder bei der Auswahl 
einer E/A-Konfiguration auf. 

Die Sprungtabelle ersetzt eine ganze Serie von bedingten Sprung-Operatio¬ 
nen. Das Programm, das auf die Sprungtabelle zugreift, könnte zum Zugriff auf 
mehrere unterschiedliche Tabellen verwendet werden, indem einfach die nach¬ 
indizierte oder indirekte indizierte Adressier-Art verwendet wird, bei der die 
Start-Adresse der Tabelle in das RAM auf Seite null plaziert wird 

Die Daten müssen mit 2 multipliziert werden, um den richtigen Index zu erge¬ 
ben, da jede Eingabe in der Sprungtabelle zwei Bytes belegt. 

Der Befehl JMP ($40) verwendet indirekte Adressierung. Der Bestimmungsort 
ist die Adresse, die in die spezifizierte Speicherstelle anstatt die spezifizierte 
Speicherstelle selbst gespeichert ist. JMP ist der einzige Befehl des 6502, der 
indirekte Adressierung verwendet. Beachten Sie, daß es keine Nullseiten Be 
triebsart gibt und daß die Adresse auf die gebräuchliche Art des 6502 gespei 
chert wird, mit den niedrigstwertigen Bits zuerst. 


Die Terminologie, die bei der Beschreibung von 
Sprung- oder Verzweigungsbefehlen verwendet 
wird, ist häufig verwirrend. Ein Sprungbefehl, der 
mit Verwendung direkter Adressierung beschrie¬ 
ben wird, lädt in Wirklichkeit die spezifizierte Adresse in den Befehlszähler. Dies 
arbeitet mehr wie unmittelbare Adressierung als direkte Adressierung, wie sie 
bei anderen Befehlen wie Laden oder Speichern angewendet wird. Ein Sprung¬ 
befehl unter Verwendung indirekter Adressierung arbeitet wie ein anderer Befehl 
mit Veiwendung direkter Adressierung. 

Es ist keine Abschluß-Operation erforderlich (wie ein BRK-Befehl), da JMP ($40) 
die Steuerung zu der Adresse transferiert, die von der Sprungtabelle enthalten 
wird, 

Literatur 7 und 8 enthalten zusätzliche Beispiele für die Verwendung von 
Sprungtabellen. Das Programm nimmt an, daß die Sprungtabelle weniger als 
128 Einheiten enthält (weshalb?). Wie könnten Sie das Programm ändern, um 
längere Tabellen zu ermöglichen? 


SPRUNG-UND 
VERZWEIGUNGS¬ 
TERMINOLOGIE 
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AUFGABEN 


1) Entfernen einer Eingabe aus einer Liste 

Zweck: Entferne den Inhalt des Speicherplatzes 0040 aus einer Liste, wenn die¬ 
ser vorliegt. Die Länge der Liste befindet sich im Speicherplatz 0041, 
und die Liste selbst beginnt im Speicherplatz 0042, Bringe die Eingaben 
unter die eine, die um eine Stelle nach oben bewegt wurde, und verrin¬ 
gere die Länge der Liste um 1. 

Beispiele: 

a (0040) = 6 B aus der Liste zu entfernende Eingabe 

(0041) = 04 Länge der Liste 

(0042) = 37 erstes Element in der Liste 
(0043) - 61 

(0044) = 28 

(0045) = ID 

Ergebnis; Keine Änderung, da die Eingabe nicht in der Liste ist. 

b (0040) - 6 B aus der Liste zu entfernende Eingabe 

(0041) - 04 Länge der Liste 

(0042) - 37 erstes Element in der Liste 
(0043) - 6 B 

(0044) = 28 

(0045) = ID 

Ergebnis: (0041) - 03 Länge der Liste wird um 1 vermindert 

(0042) = 37 

(0043) = 28 die anderen Elemente in der Liste werden um 
1 Position nach oben verschoben 

(0044) = ID 

Die Eingabe wird aus der Liste entfernt, und die eine unterhalb wird um eine Po¬ 
sition nach oben verschoben. Die Länge der Liste wird um 1 verringert. 
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2) Hinzufügen einer Eingabe zu einer geordneten Liste 

Zweck: Plaziere den Inhalt des Speicherplatzes 0040 in eine geordnete Liste, 
wenn sie nicht bereits vorhanden ist. Die Länge der Liste liegt im Spei¬ 
cherplatz 0041, und die Liste selbst beginnt im Speicherplatz 0042 und 
besteht aus Binärzahlen ohne Vorzeichen in steigender Reihenfolge. 
Plaziere die neue Eingabe in die richtige Position in der Liste, ordne die 
Elemente unter dieser an. und erhöhe die Länge der Liste um 1. 

Beispiele: 

a. (0040) - 6 B zur Liste hinzuzufügende Eingabe 

(0041) - 04 Länge der Liste 

(0042) - 37 erstes Element in der Liste 

(0043) - 55 

(0044) - 7D 

(0045) - AI 

Ergebnis: (0041) - 05 Länge der Liste wird um 1 erhöht 

(0044) 6 B in die Liste plazierte Eingabe 
(0045) = 7D die anderen Elemente in der Liste werden um 
eine Position nach unten verschoben 

(0046) - AI 

b. (0040) - 6 B zur Liste hinzuzufügende Eingabe 

(0041) = 04 Länge der Liste 

(0042) - 37 erstes Element in der Liste 

(0043) = 55 

(0044) = 6 B 

(0045) = AI 

Das Ergebnis besteht darin, daß keine Änderung erfolgt, da 
die Eingabe bereits in der Liste vorhanden ist. 
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3) Addieren eines Elementes zu einer Warteschlange 


4) 16-Bit-Sortierung 


Zweck: Addiere die Adresse in den Speicherplätzen 0040 und 0041 (MSBs in 
0041) zu einer Warteschlange. Die Adresse des ersten Elementes der 
Schlange liegt in den Speicherplätzen 0042 und 0043 (MSBs in 0043). 
Jedes Element in der Schlange enthält entweder die Adresse des näch¬ 
sten Elementes in der Schlange oder null, wenn es kein nächstes Ele¬ 
ment gibt. Alle Adressen sind 16 Bits lang, mit den niedrigstwertigen 
Bits im ersten Byte des Elementes. Das neue Element gelangt zum 
Ende (Schwanz) der Schlange. Seine Adresse wird in dem Element lie¬ 
gen, das am Ende der Schlange lag, und wird null enthalten um anzu¬ 
zeigen. daß es nun das Ende der Warteschlange ist. 


Beispiel: 


Ergebnis: 


(0040) 

- 

4D 

(0041) 

- 

00 

(0042) 

- 

46 

(0043) 


00 

(0046) 


00 

(0047) 

“ 

00 

(0046) 

_ 

4D 

(0047) 


00 

(004D) 


00 

(004E) 

- 

00 


"1 Neues Element, das der Warte- 
/ schlänge hinzuzufügen ist. 

| Zeiger zum Kopf der Warteschlange 

| Letztes Element in der Warteschlange 

"I Altes letztes Element zeigt zum 
J neuen letzten Element 

1 Neues letztes Element in der 
J Waileschlange 


Wie würden Sie ein Element zur Warteschlange hinzufügen, wenn die Speicher¬ 
plätze 0044 und 0045 die Adresse des Schwanzes der Warleschlange (das letz¬ 
te Element) enthalten würden? 


Zweck: Sortiere eine Reihe von 16-Bit-Binärzahlen ohne Vorzeichen in abstei¬ 
gender Reihenfolge. Die Länge der Reihe befindet sich im Speicher¬ 
platz 0040, und die Reihe selbst beginnt im Speicherplatz 0041, Jede 


16 Bit-Zahl wird 

mit 

den 

höchstwertigen Bits im ersten Byte gespei 

chert. 





Beispiel: 

(0040) 


03 

Länge der Liste 


(0041) 

- 

Dl 

LSBs des ersten Elementes in der Liste 


(0042) 

- 

19 

MSBs des ersten Elementes in der Liste 


(0043) 

- 

60 



(0044) 

- 

3F 



(0045) 

- 

2A 



(0046) 

- 

B5 


Ergebnis: 

(0041) 

- 

2A 

LSBs des ersten Elementes in der 
geordneten Liste 


(0042) 


B5 

MSBs des ersten Elementes in der 
geordneten Liste 


(0043) 


60 



(0044) 

- 

3F 



(0045) 

- 

Dl 



(0046) 

- 

19 



Die Zahlen sind B52A, 3F60 und 19D1. 

5) Verwendung einer Sprungtabelle mit einem Schlüssel 

Zweck: Verwende den Inhalt des Speicherplatzes 0040 als Schlüssel zu 
einer Sprungtabelle, die im Speicherplatz 0041 beginnt. Jede Ein¬ 
gabe in die Sprungtabelle enthält einen 8-Bit Schlüsselwert, gefolgt 
von einer 16-Bit-Adresse (MSBs im ersten Wort), zu der das Pro 
gramm die Steuerung transferieren sollte, wenn der Schlüssel 
gleich dem Schlüsselwert ist. 


Beispiel: 


Ergebnis: 


(0040) 

“ 

38 

Schlüssel-Wert für Suchen 

(0041) 

_ 

32 

Schlüssel-Wert für erste Eingabe 

(0042) 

" 

4A 

LSBs der Sprungadresse für erste 
Eingabe 

(0043) 


00 

MSBs der Sprungadresse für erste 
Eingabe 

(0044) 

_ 

35 


(0045) 

- 

4E 


(0046) 


00 


(0047) 

- 

38 


(0048) 

- 

52 


(0049) 

- 

00 


(PC) - 

005F, 

da die Adresse mit dem 
Schlüsselwert 38 übereinstimmt. 


s 
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Kapitel 10 

UNTERPROGRAMME 


Keiner der bisher geeigneten Beispiele stellt ein Programm für sich selbst dar. 
Die meisten realen Programme führen eine Serie von Aufgaben aus, und viele 
von ihnen können gleich sein oder gemeinsam in unterschiedlichen Program¬ 
men Vorkommen. Wir benötigen daher einen Weg, um diese Aufgaben einmal 
zu formulieren und sie dann bequem in verschiedenen Teilen des momentanen 
Programmes und in anderen Programmen verfügbar zu machen. 


6 "Sortmg 30 Times Fasler with DPS", Datamation, February 1978, pp. 
200-203. 

7. L. A. Leventhal, "Cut Your Processor’s Computation Time". Electronic 
Design, August 16, 1977, pp. 82-89. 
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Die Standard-Methode besteht darin, Unterpro¬ 
gramme zu schreiben, die spezielle Aufgaben aus¬ 
führen. Die sich ergebenden Sequenzen von Befeh- 
fehlen können einmal geschrieben, getestet und dann wiederholt werden. Sie 
können eine Unterprogramm-Bibliothek bilden, die dokumentierte Lösungen 
für allgemeine Probleme liefert. 

Die meisten Mikroprozessoren besetzen spezielle 
Befehle für die Übergabe der Steuerung an Unter¬ 
programme und das Zurückgeben der Steuerung 
zum Hauptprogramm. Wir beziehen uns häufig auf den speziellen Befehl, der 
die Steuerung einem Unterprogramm mittels Aufruf (Call), Springe-zu-Unterpro- 
gramm (Jump to Subroutine), Springe-und-markiere Stelle (Jump and Mark 
place) oder Springe-und verbinde (Jump and Link) übergibt Der spezielle Be¬ 
fehl, der die Steuerung dem Hauptprogramm zurückgibt, wird gewöhnlich Rück¬ 
kehr (Return) genannt. Beim Mikroprozessor 6502 bewahrt der Befehl "Spnnge 
zu Unterprogramm" (JSR = Jump to Subroutine) den alten Wert des Be¬ 
fehlszählers im RAM Stapel auf. bevor er die Start-Adresse des Unterpro¬ 
gramms in den Befehlszähler plaziert. Der Befehl "Kehre von Unterprogramm 
zurück" (RTS- Return from Subroutine) holt den alten Wert vom Stapel und legt 
ihn zurück in den Befehlszähler. Der Zweck besteht im Transfer der Programm¬ 
steuerung. zuerst zum Unterprogramm und dann zurück zum Hauptprogramm. 
Natürlich kann das Unterprogramm selbst die Steuerung an ein weiteres Unter¬ 
programm abgeben, usw. 

Um wirklich von Nutzen zu sein, muß ein Unterprogramm universell ausgelegt 
werden. Eine Routine, die nur eine spezialisierte Aufgabe ausführen kann, wie 
etwa das Suchen nach einem bestimmten Buchstaben in einer Eingangsreihe 
fester Länge, wird nicht sehr nützlich sein. Wenn andererseits das Unterpro¬ 
gramm jeden Buchstaben in einer Reihe beliebiger Länge aufsuchen kann, so 
wird dies wesentlich nützlicher sein. Wir nennen die Daten oder Adressen, die 
dem Unterprogramm Abänderungen gestatten. "Parameter". Ein wesentlicher 
Teil beim Schreiben von Unterprogrammen besteht in der Entscheidung, welche 
Variablen Parameter sein sollen. 


UNTERPROGRAMM- 

BEFEHLE 


UNTERPROGRAMM¬ 

BIBLIOTHEK 
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Ein Problem besteht im Transferieren der Parameter in das 
Unterprogramm Dieser Vorgang wird die "Übergabe von 
Parametern” (passing Parameters) genannt. Das einfachste 
Verfahren besteht für das Hauptprogramm darin, die Parameter in Register zu 
plazieren. Dann kann das Unterprogramm einfach annehmen, daß sich die Para¬ 
meter dort befinden. Natürlich ist diese Technik durch die Anzahl der verfüg¬ 
baren Register begrenzt. Die Parameter können jedoch so wie Daten adressiert 
werden. Beispielsweise könnte eine Sortier-Routine mit dem Index-Regfster X 
beginnen, das die Adresse auf der Null-Seite enthält, in der die Länge der An¬ 
ordnung liegt 

Der Mikroprozessor 6502 Ist durch die Ta ache begrenzt, daß er keine Regi¬ 
ster für die volle Adressenlänge (16 0*11) besitzt, in die entsprechend lange Pa¬ 
rameter übergeben werden können. Es können jedoch derartige Parameter 
leicht übertragen werden, Indem Speicherplätze auf Seite Null reserviert wer¬ 
den. Diese Speicherplätze arbeiten effektiv als zusätzliche Register. Ein weite¬ 
rer Vorteil dieser Lösung besteht darin, daß auf Adressen auf der Nullseite un¬ 
ter Verwendung der nach-lndizierten (indirekt indizierten) und vor-indizierten 
(indizieiten indirekten) Adressierung zugegriffen werden kann, als auch mit 
den kurzen Nullseiten-Formen der direkten und indizieiten Adressierung. 


ÜBERGABE VON 
PARAMETERN 


WIEDEREINTRITTS¬ 

UNTERPROGRAMM 


In ein Unterprogramm kann erneut eingetreten 
werden (es ist ’re-entrant”), wenn es durch das 

Unterbrechungsprogramm unterbrochen wird - 

und in das Unterprogramm erneut eingetreten werden kann, und sowohl kor¬ 
rekte Ergebnisse für das unterbrechende als auch das unterbrochene Pro¬ 
gramm ergibt. Die Möglichkeit des Wieder-Eintretens ist wichtig für Standard- 
Unterprogramme in einem System, das aut Unterbrechungen basiert Andern¬ 
falls kann die Unterbrechungs-Service-Routine die Standard-Unterprogramme 
mcht verwenden, ohne daß Fehler entstehen. Mikroprozessor-Unterprogramme 
sind leicht derartig auszubilden, da der Aufruf-Befehl den Stapel verwendet und 
dieses Verfahren ergibt den Wiedereintritt automatisch. Die einzig bleibende 
Forderung ist die, daß das Unterprogramm die Register und den Stapel verwen¬ 
det, anstatt feste Speicherplätze für zeitweiliges Speichern. Dies ist ein weniq 
mühsam, kann jedoch, falls nötig, ausgeführt werden. 


Ein Unterprogramm ist rekursiv, wenn es sich selbst aufruft. In ein derartiges 
Unterprogramm muß natürlich auch wiedereingetreten werden können. Rekursi¬ 
ve Unterprogramme sind jedoch in Mikroprozessor-Anwendungen nicht 
gebräuchlich. 


Eine weitere Möglichkeit besteht in der Verwendung des Stapels. Das Hauptpro¬ 
gramm kann die Parameter in den Stapel plazieren und das Unterprogramm 
kann sie von dort zurückgewinnen. Die Vorteile dieses Verfahrens liegen darin, 
daß der Stapel gewöhnlich ziemlich lang ist (bis zu einer Seite), und daß Daten 
im Stapel nicht verloren gehen, auch wenn der Stapel erneut verwendet wird. 
Der Nachteil ist darin zu sehen, daß wenige Befehle "Springe zu Unterpro¬ 
gramm" die Rückkehr-Adresse in den Stapel speichert. 

Ein anderes Verfahren besteht in der Verwendung eines Speicherbereichs für 
Parameter. Das Hauptprogramm kann die Adresse dieses Bereichs in der Null- 
Seite plazieren, und das Unterprogramm kann die Daten, falls nötig, von dort 
unter Verwendung vorindizierter Adressierung zurückgewinnen. Dieses Verfah¬ 
ren ist jedoch mühsam, wenn die Parameter selbst Adressen sind. 

Manchmal muß ein Unterprogramm spezielle Eigenschaften 
besitzen. Ein Unterprogramm ist verschiebbar (reloca- 
table), wenn es überall im Speicher plaziett werden kann. Man kann ein derarti¬ 
ges Programm leicht verwenden, unabhängig von der Plazierung anderer Pro¬ 
gramme od£r der Anordnung des Speichers. Ein völlig verschiebbares Pro¬ 
gramm kann keine absoluten Adressen verwenden. Alle Adressen müssen re¬ 
lativ zum Start des Programms sein. Ein verschiebbarer Lader ist erforderlich, 
um das Programm ordnungsgemäß in den Speicher zu plazieren. Der Lader 
wird das Programm nach anderen Programmen starten, und die Start-Adresse 
oder Verschiebungs-Konstante zu allen Adressen in dem Programm addieren. 


Die meisten Programme bestehen aus einem Hauptprogramm und mehreren 
Unterprogrammen. Dies Ist voiteilhaft, da man erprobte Routinen verwenden, 
sowie die anderen Unterprogramme separat auf Fehler untersuchen und te¬ 
sten kann. Man muß jedoch sorgfältig bei der ordnungsgemäßen Verwendung 
der Unterprogramme Vorgehen und sich daran erinnern, welche genauen Ein¬ 
flüsse sie auf Register und Speicherplätze haben. 

UNTERPROGRAMM-DOKUMENTATION 

Auflistungen von Unterprogrammen müssen ge¬ 
nügend Informationen liefern, so daß der An¬ 
wender die interne Struktur der Unterprogram¬ 
me nicht prüfen müssen. Zu diesen notwendigen 
Spezifikationen gehören; 

• Eine Beschreibung des Zweckes des Unterprogramms 

• Eine Liste der Eingabe- und Ausgabe-Parameter 

• Verwendete Register und Speicherplätze 

• Ein Beispiel 

Wenn diese Richtlinien befolgt werden, wird das Unterprogramm leicht zu ver¬ 
wenden sein. 


VERSCHIEBUNG 


DOKUMENTATION 
VON UNTER¬ 
PROGRAMMEN 
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BEISPIELE 


Wichtige Anmerkung: Alle folgenden Beispiele reservieren einen Speicherbe¬ 
reich für den RAM-Stapel, 

Wenn der Monitor in Ihrem Mikrocomputer einen derartigen Bereich verwendet, 
können Sie ihn stattdessen verwenden. Wenn Sie Ihren eigenen Stapelbereich 
einrichten wollen, erinnern Sie steh daran, den Stapelzeiger des Monitors aufzu¬ 
bewahren und zurückzuspeichern, um eine ordnungsgemäße Rückkehr am 
Ende Ihres Hauptprogrammes sicherzustellen. 

Um den Monitor-Stapelzeiger aulzubewahren, verwenden Sie die Belehlsse- 
quenz 

tcy 

STX TEMP 

Um den Monitor-Stapelzeiger zurückspeichern, verwenden Sie die Sequenz 

LDX TEMP 
TXS 

Beachten Sie das der Stapelzeiger nür über Register X geladen oder gespei¬ 
chert werden kann. Erinnern Sie sich daran, daß der 6502 immer seinen Stapel 
auf Seite eins des Speichers aufbewahrt, so daß die wirkliche Stapel-Adresse 
01 ss ist, wobei ss der Inhalt des 8-Bit-Stapelzeiger Registers ist. 

Wir haben die Adresse 01 FF, S als Startpunkt für den Stapel verwendet. Sie müs¬ 
sen vielleicht diese Adresse durch eine geeignetere für Ihre Konfiguration erset¬ 
zen. Hierzu sollten Sie das Anwender Handbuch Ihres Mikrocomputers nach¬ 
schlagen, um die erforderlichen Änderungen zu bestimmen. 

Die grundlegende Sequenz zur Initialisierung des Stapelzeigers ist daher 

LDX # $FF PLAZIERE STAPEL AM OBEREN ENDE VON 
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Hexadezimal in ASCII 


Zweck: Wandle den Inhalt des Akkumulators von einer Hexadezimalzahl-Ziffer 
in ein ASCII-Zeichen um. Nimm an, daß der Akkumulator ursprünglich 
eine einzelne gültige hexadezimale Ziffer enthält. 

Beispiele: 

(A) - OC 
(A) = 43 ASCII C 
Ergebnis: (A) - 06 

(A) - 36 ASCII6 


Flußdiagramm: 




Das Aufruf-Programm beginnt den Stapel im Speicherplatz 01 FF, holt die Da¬ 
ten vom Speicherplatz 0040, ruf: das Umwandlungs-Unterprogramm auf und 
speichert das Ergebnis in den Speicherplatz 0041. 



•-0 

LDX 

#$FF 

.PLAZIERE STAPEL AM ENDE VON SEITE 1 


TXS 

LDA 

$40 

iHOLE HEXADEZIMAL-DATEN 


JSR 

ASDEC 

;WANDLE DATEN IN ASCII UM 


STA 

$41 

iSPEICHERE ERGEBNIS 

BRK 

Das Unterprogramm wandelt die hexadezimalen Daten in ASCII um 

ASDEC 

*-$20 

CMP 

#10 

;SIND DIE DATEN EINE DEZIMALZIFFER? 


BCC 

ADC 

ASCZ 
# ’A-’9-2 

;NEIN, ADDIERE OFFSET FÜR BUCHSTABEN 

ASCZ 

ADC 

#'0 

;WANDLE IN ASCII DURCH ADDITION VON 


RTS 


; ASCII NULL UM 
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Unterprogramm-Dokumentation: 


(UNTERPROGRAMM ASDEC 

•ZWECK: ASDEC WANDELT EINE HEXADEZIMAL-ZIFFER IM AKKUMULATOR 
: IN EINE ASCII-ZIFFER IM AKKUMULATOR UM 

■ANFANGSBEDINGUNGEN: HEX-ZIFFER IN A 

iENDBEDINGUNGEN: ASCII-ZEICHEN IN A 

•VERWENDETE REGISTER: A 

:BEI SPIEL 

; ANFANGSBEDINGUNGEN- 6 IM AKKUMULATOR 
; ENDBEDINGUNGEN: ASCII 6 (HEX 36) 

; IM AKKUMULATOR 


Objektprogramme 



Die Befehle LDX #$FF und TXS beginnen den Stapel im Speicherplatz 01 FF. 
Erinnern Sie sich daran, daß der Stapel nach unten wächst (zu niedrigeren 
Adressen), und daß der Stapelzeiger des 6602 immer die Adresse auf Seite 1 
der nächsten leeren Speicherstelle enthält (anstatt die zuletzt gelüllte, wie bei 
einigen anderen Mikroprozessoren). 
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Der Befehl 'Springe zu Unterprogramm 1 ' plaziert die Start-Adresse des Unter¬ 
programms (0020) in den Befehlszähler und bewahrt den momentanen Stand 
des Befehlszählers (die Adresse des letzten Bytes des JSR-Befehls) im Stapel 
auf. Der Vorgang sieht folgendermaßen aus: 

Schritt 1) Rette MSBs des alten Befehlszähler-Standes in den Stapelzeiger, 
dekrementiere Stapelzeiger. 

Schritt 2) Rette LSBs des alten Befehlszähler-Standes in den Stapel, dekre¬ 
mentiere Stapelzeiger. 


sicher? wurden ^ S,ape,Ze ' 9er dekremen.iert wird, nachdem die Daten ge- 




Das Ergebnis in diesem Beispiel ist: 

(01 FF) - 00 
(01 FE) = 07 
(S) « FD 

Der Wert, den der Befehl Jump to Subroutine'' aufbewahrt, (st der Belehlszäh 

KifÄ’SÄÄrra 

Ergebnis zurück ,n den Befehlszähler Das Verfahren lautet d 

Schott 1 ) Inkrementiere Stapelzeiger, lade acht Bits vom Stapel plaziere Er¬ 
gebnis in LSBs des Befehlszählers. p e tr 

Schritt 2 ) Inkrementiere Stapelzeiger, (ade acht Bits vom Stapel plaziere Er¬ 
gebnis in MSBs des Befehlszählers. piaziere tr 

Schritt 3) Inkrementiere Belehlszähler, bevor ein Befehl wirklich geholt wird. 

Hier wird der Stapelzeiger inkrementiert, bevor die Daten geladen werden. 

Das Ergebnis in diesem Fall ist: 

PC = (00FF)(00FE) + 1 
- 0008 
(SP) =. FF 

^P^^ß^^de^Ergebnisse^in 

“ÄsSSJÄ" 1 h ” ,ta auch< ”" s,ice '" a ” 


10-7 





In das Unterprogramm kann wieder eingetreten werden (re-entrant), da es kei¬ 
nen Datenspeicher verwendet Es ist auch verschiebbar (relocatable), da die 
Adresse ASCZ nur in einem Befehl für eine bedingte Verzweigung mit relativer 
Adressierung verwendet wird 

Beachten Sie. daß der Befehl "Springe zu Unterprogramm" in einer Ausführung 
von vier oder fünf Befehlen resultiert und hierbei 1 3 oder 14 Taklzyklen benötigt 
Ein Unterprogramm-Aufruf kann daher in einer längeren Ausführungszeit resul¬ 
tieren. auch wenn es so aussieht, als ob er nur ein einzelner Befehl im Pro¬ 
gramm wäre. 

Wenn Sie planen, den Stapel zur Übergabe von Parameter zu verwenden, so er¬ 
innern Sie sich daran, daß JSR die Rückkehr-Adresse in der Spitze des Stapels 
aufbewahrt _ 

Sie können den Stapelzeiger zum Indexregister X bringen, um auf die Daten zu¬ 
greifen zu können, müssen sich jedoch daran erinnern, die richtigen Versetzun¬ 
gen zu liefern. Sie können auch den Zugriff auf die Daten erhalten, indem Sie 
zwei zusätzliche PLA-Befehle zur Übertragung des Stapelzeigers zurück zur 
Rückkehr-Adresse verwenden, müssen sich jedoch daran erinnern, den Stapel¬ 
zeiger wieder zurück auf seinen ursprünglichen Wert vor der Rückkehr einzu- 
slellen. 


Lange einer Zeichenreihe 

Zweck: Bestimme die Länge einer Reihe von ASCII-Zeichen. Die Start-Adresse 
der Reihe befindet sich in den Speicherplätzen 0040 und 0041. Das 
Ende der Reihe wird durch ein Wagenrücklauf-Zeichen (CR, OD,*) mar¬ 
kiert. Plaziere die Länge der Reihe (ausschließlich des Wagenrücklaufs) 
in den Akkumulator. 


Beispiele: 


a 

(0040) 

. 

43 

Startadresse der Reihe 

(0041) 


00 



(0043) 

* 

52 

'R' 


(0044) 

- 

41 

A' 


(0045) 

- 

54 

T 


(0046) 

- 

48 

■H’ 


(0047) 

- 

45 

■E’ 


(0048) 

- 

52 

■R' 


(0049) 


0D 

■CR' 

Ergebnis: 

(A) 


06 


b. 

(0040) 

_ 

0343 Startadresse der Reihe 


(0041) 


00 



(0043) 

- 

0D 


Ergebnis: 

(A) 

- 

00 
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Flußdiagramm: 



Quellprogramm: 

Das Aufruf-Programm startet den Stapel im Speicherplatz 01 FF, speichert die 
Start-Adresse der Reihe in die Speicherplätze 0040 und 0041, ruft das Unterpro¬ 
gramm für die Reihenlänge auf und speichert das Ergebnis in den Speicherplatz 


Die Speicherplätze 0040 und 0041 werden verwendet, als ob sie zusätzliche Re¬ 
gister wären. 

*-0 

LDX #$FF PLAZIERE STAPEL AM ENDE VON SEITE 1 

TXS 

LDA #$43 ;8EWAHRE STARTADRESSE DER REIHE AUF 

STA $40 
LDA #0 
STA $41 

JSR $TLEN BESTIMME LÄNGE DER REIHE 

STA $42 ;SPEICHERE REIHENLÄNGE 

BRK 
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Das Unterprogramm bestimmt die Länge der Reihe von ASCII-Zeichen und 
plaziert die Länge in den Akkumulator B 


Objektprogramm: 


STLEN 

*-$20 

LDY 

LDA 

#$FF 

#$0D 

CHKCR 

INY 

CMP 

($40).Y 


BNE 

TYA 

CHKCR 


RTS 



REIHENLÄNGE = 1 

HOLE ASCII-WAGENRUCKLAUF FÜR VER¬ 
GLEICH 

ADDIERE 1 ZUR REIHENLANGE 
IST NÄCHSTES ZEICHEN EIN WAGENRÜCK¬ 
LAUF? 

NEIN HALTE WEITER AUSSCHAU 
BEWAHRE REIHENLÄNGE IN AKKUMULA¬ 
TOR AUF 


Unterprogramm-Dokumentation: 


UNTERPROGRAMM 

ZWECK- STLEN BESTIMMT DIE LÄNGE EINER ASCII-REIHE (ANZAHL DER 
ZEICHEN VOR EINEM WAGENRÜCKLAUF) 

ANFANGSBEDINGUNGEN START-ADRESSE DER REIHE IN DEN SPEICHER 
PLÄTZEN 0040 UND 0041 

ENDBEDINGUNGEN: ANZAHL DER ZEICHEN IN A 

VERWENDETE REGISTER: A, Y. ALLE FLAGS AUSSER ÜBERLAUF 
VERWENDETE SPEICHERPLÄTZE: 0040. 0041 

BEISPIEL 

ANFANGSBEDINGUNGEN: 0043 IN DEN SPEICHERPLÄTZEN 0040UND 
0041 

(0043) - 35. (0044) - 46, (0045) = OD 
ENDBEDINGUNGEN: (A) -02 



Speicher-Adresse 

(Hex) 

Speicher-I nhalt 
(Hex) 


Befehl 

(Mnemonik) 

D 

Aulrufendes Programm 





0000 

A2 


LDX 

#$FF 


0001 

FF 





0002 

9A 


TXS 



0003 

A9 


LDA 

#$43 


0004 

43 





0005 

65 


STA 

$40 


0006 

40 





0007 

A9 


LDA 

#0 


0006 

00 





0009 

65 


STA 

$41 


000A 

41 





0006 

20 


JSR 

STLEN 


oooc 

20 





000D 

00 





000E 

85 


STA 

$42 


000F 

42 





0010 

00 


6RK 


2) 

Unterprogramm 






0020 

A0 

STLEN 

LDY 

#$FF 


0021 

FF 





0022 

A9 


LDA 

#$0D 


0023 

OD 





0024 

C8 

CHKCR 

INY 



0025 

Dl 


CMP 

($40). Y 


0026 

40 





0027 

DO 


6 NE 

CHKCR 


0026 

F8 





0029 

98 


TYA 



002A 

60 


RTS 



Das aufrufende Programm besteht aus vier Schritten: Initialisieren des Stapel¬ 
zeigers, Plazieren der Startadresse der Reihen in die Speicherplätze 0040 und 
0041, Aufrufen des Unterprogramms und Speichern des Ergebnisses. 


In das Unterprogramm kann nicht wieder eingelrelen werden, da es feste Spei¬ 
cheradressen 0040 und 0041 verwendet Wenn diese Speicherplätze jedoch als 
zusätzliche Register betrachtet werden und ihr Inhalt automatisch aufbewahrt 
und mit den Anwender-Registern zurückgespeichert wird, kann das Unterpro¬ 
gramm auf eine "Wiedereintritlsarl" verwendet werden. Zahlreiche Computer 
aller Größen verwenden Register, die in Wirklichkeit im Speicher liegen. Diese 
Lösung macht das Speicher-Management komplexer, ändert jedoch nicht die 
grundlegenden Verfahren. 

Das Unterprogram m ändert das Register Y, sowie den Inhalt des Akkumulators. 
Der Programmierer muß daher darauf achten, daß die im Index-Register Y ge¬ 
speicherten Daten verloren gehen Die Dokumentation des Unterprogramms 
muß beschreiben, wozu die Register verwendet werden. 
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Ein Weg zum Aufbewahren des Register-Inhaltes während eines Unterprogram¬ 
mes besteht darin, sie in den Stapel zu legen und dann vor der Rückkehr zu¬ 
rückzuspeichern. Diese Lösung erleichtert das Leben für den Anwender der 
Routine, kostet jedoch zusätzliche Zeit und Speicher (im Programm und im 
Stapel). Um das Indexregister Y zu retten und zurückzuspeichern, müßten Sie 
folgende Sequenz hinzufügen 


TYA ;BEWAHRE ALTEN INHALT VON Y AUF 

PHA 

Zu Beginn des Programmes und 

PLA ;SPEICHERE ALTEN INHALT VON Y ZURÜCK 

TAY 

am Ende des Programmes. 

Dieses Unterprogramm besitzt einen einzelnen Eingangs-Parameter, der eins 
Adresse ist. Der einfachste Weg um diesen Parameter zu übertragen, geschieht 
über zwei Speicherplätze auf der Nullseite. Der 6502 besitzt keine Register mit 
voller Adressenlänge, mit denen diese Parameter übertragen werden könnten 

Wenn das Abschlußzeichen nicht immer ein ASCII-Wagenrücklauf wäre, könn¬ 
ten wir dieses Zeichen in einen anderen Parameter umwandeln. Nun müßte das 
aufrufende Programm das Abschlußzeichen in den Akkumulator plazieren und 
die Start-Adresseder Reihe in die Speicherplätze 0040 und 0041. bevor das Un¬ 
terprogramm aufgerufen wird. 

Ein Weg zum Übertragen von Parametern, die für einen bestimmten Aufruf fest¬ 
liegen, besteht im Plazieren ihrer Werte in den Programmspeicher, unmittelbar 
nach dem Befehl Jump-to-Subroutine 1 Sie können den alten Befehlszähler 
(aufbewahrt in der Spitze des Stapels) zum Zugriff auf die Daten verwenden, 
müssen jedoch die Rückkehr-Adresse einrichten (Erhöhung um die Anzahl der 
für Parameter verwendeten By(es), bevor die Steuerung zurück zum Hauptpro¬ 
gramm transferiert wird Beispielsweise könnten wir den Werl des Abschluß¬ 
zeichens auf diese Weise übertragen. Das Hauptprogramm würde die Pseudo- 
Operation BYTE’, unmitlelbar nach dem JSR-Befehl enthalten. Das Unterpro¬ 
gramm könnte die Rückkehr-Adresse in die Speicherplätze 0050 und 0051 pla¬ 
zieren und auf die verschiedenen Parameter unter Verwendung von Nach-Indi- 
zierung zugreifen. Die folgende Sequenz könnte die Rückkehr-Adresse aufbe¬ 
wahren, wobei man sich erinnere, daß der Stapel immer auf Seite 1 des Spei¬ 
chers liegt und der Stapelzeiger immer die Adresse der nächsten verfügbaren 
Speicherstelle enthält. 

TSX ;HOLE STPELZEIGER 

LDA SOI 01 ,X ;HOLE MSB'S DER RUCKKEHRADRESSE 

STA $50 

LDA $0102,X ;HOLELSB S DER RÜCKKEHRADRESSE 
STA $51 

Achten Sie sehr sorgfältig auf die Tatsache, daß die Rückkehr-Adresse in Wirk¬ 
lichkeit die Adresse des letzten (dritten) Bytes des JSR-Befehls ist, nicht die 
Adresse unmittelbar nach dem JSR-Befehl, wie dies bei den meisten anderen 
Mikroprozessoren der Fall ist. Die tatsaächliche Rückkehr-Adresse muß daher 
um 1 versetzt werden, da RTS automatisch 1 zu ihr addieren wird. 


10-12 


§lckftmlsfeherln t ^n C r K a ( ,0r in S l ackl Und PLA < Load Accumulatorfrom 
n a 2 , h P atenblts zwischen dem Akkumulator und dem RAM- 

P Die Indexregister X und Y können nur über den Akkumulator aufbewahrt 
und zuruckgespeichert werden. Wie beim Befehl Jump-to-Subroutine wird der 

Hpn P nnH e ' 9 < L r dekre , men, ' ert ' nachdem die Daten in den Stapel gespeichert wur- 
den und inkrementiert, bevor die Daten von ihm geladen werden Erinnern Sie 
sich daran, daß der RAM-Stapel abwärts wächst (zu niedrigeren Adressen) 


Maximalwert 

Zweck: Suche das größte Element in einem Block von Binärzahlen ohne Vorzei¬ 
chen. Die Länge des Blockes befindet sich im Indexregister Y und die 
Stailadresse des Blocks liegt in den Speicherplätzen 0040 und 0041 
Der Maximalwert wird in den Akkumulator zurückgelegt. 

Beispiele: 

(Y) = 05 Länge des Blocks 
(0040) => 43 Startadresse des Blocks 
(0041) = 00 

(0043) - 67 
(0044) - 79 
(0045) - 15 
(0046) - E3 
(0047) - 72 

Ergebnis. (A) = E3, da dies die größte von fünf Zahlen ohne 

Vorzeichen ist. 
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Flußdiagramm: 


Das Unterprogramm bestimmt den Maximalwert in dem Block 



MAXM 

*-S20 

LDA 

#0 

CMPE 

DEY 



PHP 

CMP 

($40),Y 


BCS 

NOCHG 


LDA 

($40),Y 

NOCHG 

PLP 



BNE 

CMPE 


RTS 



MAXIMUM NULL (KLEINSTMÖGLICHER 
WERT) 

DEKREMENTIERE INDEX 
BEWAHRE STATUS AUF 
IST NÄCHSTES ELEMENT ÜBER DEM MAXI¬ 
MUM? 

NEIN, BEWAHRE MAXIMUM AUF 
JA, ERSETZE MAXIMUM DURCH ELEMENT 
SPEICHERE STATUS ZURÜCK 
SETZE FORT, BIS ALLE ELEMENTE 
GEPRÜFT SIND 


Unterprogramm-Dokumentation: 


UNTERPROGRAMM MAXM 

ZWECK: MAXM BESTIMMT DEN MAXIMALWERT IN EINEM BLOCK VON 
BINÄRZAHLEN OHNE VORZEICHEN 

ANFANGSBEDINGUNGEN: STARTADRESSE DES BLOCKS IN DEN SPEICHER¬ 
PLÄTZEN 0040 UND 0041, LÄNGE DES BLOCKS IN Y 

ENDBEDINGUNGEN: MAXIMALWERT IN A 

VERWENDETE REGISTER: A, Y. ALLE FLAGS MIT AUSNAHME VON ÜBER¬ 
LAUF 

VERWENDETE SPEICHERPLÄTZE: 0040, 0041 


Quellprogramm: 


Das aufrufende Programm startet den Stapel im Speicherplatz 01 FF, setzt die 
Start-Adresse des Blockes auf 0043, holt die Blocklänge vom Speicherplatz 
0030, ruft das Unterprogramm für den Maximalwert auf und speichert das Maxi¬ 


mum in den Speicherplatz 0042 


* = 0 

LDX 

#$FF 

TXS 

LDA 

#$43 

STA 

$40 

LDA 

#0 

STA 

$41 

LDY 

$30 

JSR 

MAXM 

STA 

BRK 

$42 


iPLAZIER STAPEL AN DAS ENDE DER 
; SEITE 1 

,'BEWAHRE STARTADRESSE DES BLOCKS 
; AUF 


;HOLELÄNGE DES BLOCKES 
;SUCHE MAXIMALWERT 
•.BEWAHRE MAXIMALWERT AUF 


;BEISPIEL: 

; ANFANGSBEDINGUNGEN: 0043 IN DEN SPEICHERPLÄTZEN 0040 UND 
0041 

; (Y) =03, (0043) =35, (0040) = 46, (0045)- 0D 
; ENDBEDINGUNGEN: (A) = 46 

Dieses Unterprogramm hat zwei Parameter - eine Adresse und eine Zahl. Die 
Speicherplätze 0040 und 0041 werden zur Übergabe der Adresse verwendet, 
und das Indexregister Y dient zur Übergabe der Zahl. Das Ergebnis ist eine ein¬ 
zelne Zahl, die in den Akkumulator zurückgelegt wird. 

Das aufrufende Programm muß die Start-Adresse des Blockes in die Speicher¬ 
plätze 0040 und 0041 plazieren und die Länge des Blockes in das Indexregi¬ 
ster Y, bevor die Steuerung zum Unterprogramm transferiert wird. 
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■Bit-Nr 

Prozessor-Status 


7 fr 5 4 3 2 1 Q ■ 

Islvl IB 1 0 | I Izlcl- 




“Carry (Übertrag) 

-Zero Reduit (Null-Ergebnis) 

Jnlerrupl Disable (Unterbrechungs-Freigabe) 
-Decimat Mode (Dezimal-Betriebsart) 
-Break-Kommando 
-(nicht verwendet) 

-Overflew (Überlauf) 

-Negative Result (Sign) (Negaliv-Ergebnis, 
Vorzeichen) 


Das Unterprogramm gibt bei null die Steuerung in das Indexregister Y zurück. 
Es kann in dieses nicht wieder eingetreten werden, außer die Speicherplätze 
0040 und 0041 werden als zusätzliche Register behandelt. Es ist verschiebbar, 
da die Adressen relativ sind und der Stapel lür eine zeitweilige Speicherung ver¬ 
wendet wird. 

Beachten Sie die Verwendung der Befehle PHP und PLP, die die Statusregister 
aulbewahren und zurückspeichern. Dieses Register ist wie in Bild 10-1 organi¬ 
siert. Wir könnten das Programm organisieren und die Anfangsbedingungen än¬ 
dern, um den Bedarf für diese Befehle (siehe Kapitel 5) zu eliminieren. Der 
Schlüssel liegt hierbei darin, die Adresse um eins vor dem Start der Anordnung 
als Parameter zu lielern Dies kann sehr leicht mit den meisten Assemblern ge¬ 
schehen, da sie einfache arithmetische Ausdrücke (wie etwa START-1) im 
Operandenfeld gestatten (siehe Kapitel 3] Der Anwender des Unterprogram¬ 
mes muß jedoch gewarnt werden, daß diese Versetzung erforderlich ist. 
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Objektprogramm 



Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 


Befehl 

(Mnemonik) 

1) 

Aufrufendes Programm 





0000 

A2 


LDX 

#$FF 


0001 

FF 





0002 

9A 


TXS 



0003 

A9 


LDA 

#$43 


0004 

43 





0005 

85 


STA 

$40 


0006 

40 





0007 

A9 


LDA 

#0 








0008 

00 





0009 

85 


STA 

$41 


000A 

41 





0006 

A4 


LDY 

$30 


oooc 

30 





000D 

20 


JSR 

MAXM 


000E 

20 





000F 

00 





0010 

85 


STA 

$42 


0011 

42 





0012 

00 


BRK 


2) 

Unterprogramm 






0020 

A9 

MAXM 

LDA 

#0 


0021 

00 





0022 

88 

CMPE 

DEY 



0023 

08 


PHP 



0024 

Dl 


CMP 

($40). Y 


0025 

40 





0026 

B0 


BCS 

NOCHG 


0027 

02 





002B 

8t 


LDA 

($40). Y 


0029 

40 





002A 

28 

hJOCHG 

PLP 



002B 

DO 


8NE 

CMPE 


002C 

F5 





002D 

60 


RTS 
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Übereinstimmung von Mustern 2 

Zweck: Vergleiche zwei Reihen von ASCII-Zeichen, um leslzuslellen, ob sie 
gleich sind Oie Länge der Reihen befindet sich im Index-Register Y. 
Die Start-Adresse einer Reihe liegt in den Speicherplätzen 0042 und 
0043 Die Start-Adresse der anderen liegt in den Speicherplätzen 0044 
und 0045. Wenn die beiden Reihen übereinstimmen, lösche Akkumula¬ 
tor. Andernlalls setze Akkumulator aut FF, S - 

Beispiel: 


a. 

(Y) 

- 

03 Länge der Reihen 


(0042) 

(0043) 


q® | Startadresse von Reihe 1 


(0044) 

(0045) 


qq | Startadresse von Reihe 2 


(0046) 

_ 

43 C 


(0047) 

- 

41 'A' 


(0048) 


54 T 


(0050) 

* 

43 ’C’ 


(0051) 


41 A’ 


(0052) 


54 T 

Ergebnis: 

(A) 


00, da die Reihen gleich sind 


(Y) 

= 

03 Länge der Reihen 

b. 

(0042) 

(0043) 


46 1 

qq | Startadresse von Reihe 1 


(0044) 

(0045) 


50 1 

qq | Startadresse von Reihe 2 


(0046) 

• 

52 -R 1 


(0047) 


41 A' 


(0048) 

= 

54 T 


(0050) 


43 ’C' 


(0051) 

= 

41 ‘A’ 


(0052) 

= 

54 T 

Ergebnis: 

(A) 


FF,da sich die ersten Zeichen unterscheiden 


10-18 


Flußdiagramm: 
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Quellprogramm: 


Unterprogramm-Dokumentation: 


Das aufrufende Programm beginnt den Stapel im Speicherplatz 01 FF, setzt die 
beiden Start Adressen auf 0046 und 0050, holt die Reihenlänge vom Speicher¬ 
platz 0041, ruft das Unterprogramm für die Musterübereinstimmung auf und pla¬ 
ziert das Ergebnis in den Speicherplatz 0040. 


*= 0 
LDX 

#$FF 

;PLAZIERESTAPEL AM ENDE VON SEITE 1 

TXS 

LDA 

#$46 

;BEWAHRE STARTADRESSE VON REIHE 1 

STA 

$42 

; AUF 

LDA 

#0 


STA 

$43 


LDA 

#$50 

;BEWAHRE STARTADRESSE VON REIHE 2 

STA 

$44 

; AUF 

LDA 

#0 


STA 

$45 


LDY 

$41 

.HOLE REIHENLÄNGE 

JSR 

PMTCH 

PRÜFE AUF ÜBEREINSTIMMUNG 

STA 

$40 

;BEWAHRE ÜBEREINSTIMMUNGS- 

BRK 


; INDIKATOR AUF 


Das Unterprogramm bestimmt, ob die beiden Reihen übereinstimmen. 


*-$20 


PMTCH 

LDX 

#$FF 

MARKE- FF (HEX) FÜR KEINE ÜBEREIN¬ 




STIMMUNG 

CMPE 

DEY 




LDA 

($42). Y 

HOLE ZEICHEN VON REIHE 1 


CMP 

($44), Y 

GIBT ES EINE ÜBEREINSTIMMUNG MIT 




REIHE 2? 


BNE 

DONE 

NEIN, DONE - REIHEN STIMMEN NICHT 




ÜBEREIN 


TYA 


SPEICHERE STATUS VON INDEX ZURÜCK 


BNE 

CMPE 



LDX 

#0 

MARKE- NULL, REIHEN STIMMEN ÜBEREIN 

DONE 

TXA 




RTS 




;UNTERPROGRAMM PMTCH (PATTERN MATCH) 

■ZWECK: PMTCH BESTIMMT, OB ZWEI REIHEN LIBEREINSTIMMEN 

;ANFANGSBEDINGUNGEN: STARTADRESSE DER REIHEN IN DEN SPEICHER¬ 
PLÄTZEN 0042 UND 0043, 0044 UND 0045. LÄNGE DER REIHEN IM INDEX¬ 
REGISTER Y 

;ENDBEDINGUNGEN: NULL IN A, WENN REIHEN ÜBEREINSTIMMEN, 
ANDERNFALLS FF IN A 

■VERWENDETE REGISTER: A, X, Y, ALLE FLAGS AUSSER ÜBERLAUF 
■VERWENDETE SPEICHERPLÄTZE: 0042. 0043. 0044, 0045 
■BEISPIEL: 

; ANFANGSBEDINGUNGEN: 0046 IN 0042 UND 0043, 0050 IN 0044 UND 
; 0045, (Y)-02 

(0046) - 36. (0047) - 39, 

; (0056)-36. (0051)-39 

: ENDBEDINGUNGEN: (A) = 0, DA DIE REIHEN ÜBEREINSTIMMEN 
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Objektprogramm: 



Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 


Befehl 

(Mnemonik) 

1) 

Aufrufendes Programm 





0000 

A2 


LDX 

#$FF 


0001 

FF 





0002 

9A 


TXS 



0003 

A9 


LDA 

#$46 


0004 

46 





0005 

85 


STA 

$42 


0006 

42 





0007 

A9 


LDA 

#0 


0008 

00 





0009 

85 


STA 

$43 


000A 

43 





0008 

A9 


LDA 

#$50 


oooc 

50 





000D 

85 


STA 

$44 


000E 

44 





000F 

A9 


LDA 

#0 


0010 

00 





0011 

85 


STA 

$45 


0012 

45 





0013 

A4 


LDY 

$41 


0014 

41 





0015 

20 


JSR 

PMTCH 


0016 

20 





0017 

00 





0018 

85 


STA 

$40 


0019 

40 





OOIA 

00 


8RK 


2) 

Unterprogramm 






0020 

A2 

PMTCH 

LDX 

#$FF 


0021 

FF 





0022 

88 

CMPE 

DEY 



0023 

81 


LDA 

($42),Y 


0024 

42 





0025 

Dl 


CMP 

($44).Y 


0026 

44 





0027 

DO 


8NE 

DONE 


0028 

05 





0029 

98 


TYA 



002A 

DO 


8NE 

CMPE 


0028 

F6 





002C 

A2 


LDX 

#0 


002D 

00 





002E 

8A 

DONE 

TXA 



002F 

60 


RTS 



Dieses Unterprogramm ändert, wie das vorausgehende, alle Flags mit Ausnah¬ 
me des Überlaufs, Sie sollten im allgemeinen annehmen, daß ein Unterpro¬ 
gramm-Aufruf die Flags ändert, außer es ist andernfalls speziell festgelegt. 
Wenn das Hauptprogramm die alten Flag-Werte benötigt (für spätere Prüfung) 
muß sie diese in den Stapel vor dem Aufruf des Unterprogrammes aufbewahren. 
Dies geschieht mit dem PHP-Befehl. 

Dieses Unterprogramm verwendet alle Register und vier Speicherplätze auf 
Seite null. Es gibt drei Parameter - zwei Start-Adressen und die Länge der 
Reihe. 

Der Befehl TYA hat keinen anderen Zweck, als das Null-Flag entsprechend dem 
Inhalt von Indexregister Y zu setzen. Wir könnten den Bedarf für diesen Befehl 
eliminieren, indem wir das Unterprogramm neu organisieren. Eine Alternative 
wäre die Änderung der Parameter, so daß die Adressen beide um 1 versetzt wä¬ 
ren (d.h., beide Reihen-Adressen wurden sich in Wirklichkeit auf das Byte bezie¬ 
hen, das unmittelbar vor der Zeichenreihe kommt). Erinnern Sie sich jedoch da¬ 
ran, daß der Anwender in der Lage sein sollte. Parameter in das Unterprogramm 
auf die einfachste und möglichst Offensichtlichste Weise zu übertragen. Der An¬ 
wender sollte nicht Adressen um 1 versetzen oder andere Anordnungen für das 
Unterprogramm ausführen müssen. Derartigen Praktiken resultieren in zahlrei¬ 
chen unangenehmen Programmierfehlern. Das Programm sollte derartige Dinge 
nur ausführen, wenn Zeit oder Speicher-Überlegungen kritisch sind. 

Eine weitere Alternative bestünde im Dekrementieren des Index um 1 zu Beginn, 
um das Problem des Zugriffes nach dem Ende der Reihe zu vermeiden. Das 
Ende der Schleife würde dann den Index dekrementieren und zurück verzwei¬ 
gen. solange das Resultat positiv ist, das heißt 

DEY 

BPL CMPE 

Diese Lösung würde solange arbeiten, solange die Reihe kürzer als 130 Bytes 
ist. Die Begrenzung tritt auf, da das Vorzeichen-Flag des 6502 gesetzt wird, 
wenn das Ergebnis einer Zahl ohne Vorzeichen größer als 127 (dezimal) ist. 
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Addition mit mehrfacher Genauigkeit 

Zweck: Addiere zwei Mehrwort-Binärzahlen Die Länge der Zahlen (in Byles) 
befindet sich im Index-Register Y, die Starl-Adressen der Zahlen in den 
Speicherplätzen 0042 und 0043, und in 0044 und 0045, und die Start- 
Adresse des Ergebnisses befindet sich in den Speicherplätzen 0046 
und 0047. Alle Zahlen beginnen mit den höchstwertigen Bits 


Beispiel: 


Ergebnis: 


(Y) 

= 

04 

(0042) 

=, 

48\ 

(0043) 

= 

00/ 

(0044) 

= 

4C \ 

(0045) 

= 

00/ 

(0046) 


50 \ 

(0047) 

“ 

00/ 

(0048) 

_ 

2F 

(0049) 


5B 

(004A) 

- 

A7 

(004B) 


C3 

(004C) 


14 

(004D) 

= 

DF 

(004E) 

- 

35 

(004F) 

= 

B8 

(0050) 

= 

44 

(0051) 

- 

3A 

(0052) 

- 

DD 

(0053) 

- 

7B 

d.h. 2F5BA7C3 


Länge der Zahlen in Bytes 
Slarladresse der ersten Zahl 

Startadresse der zweiten Zahl 

Slartadresse des Ergebnisses 
MSBs der ersten Zahl 

LSBs der ersten Zahl 
MSBs der zweiten Zahl 

LSBs der zweiten Zahl 
MSBs des Ergebnisses 

LSBs des Ergebnisses 


+14DF35B8 


443ADD7B 
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Flußdiagramm: 



Dieser Schrill erzeugt auch einen 
neuen Übertrag 
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Quellprogramm: 


Unterprogramm-Dokumentation: 


Das Aufruf-Programm beginnt den Stapel im Speicherplatz 01 FF, setzt die 
Start-Adressen der verschiedenen Zahlen entsprechend auf 0048, 004C und 
0050, holt die Länge der Zahlen vom Speicherplatz 0040 und ruft das Unterpro¬ 
gramm für die Addition mit mehrfacher Genauigkeit auf. 


*-0 


LDX 

#$FF 

TXS 

LDA 

#$48 

STA 

$42 

LDA 

#$4C 

STA 

$44 

LDA 

#$50 

STA 

$46 

LDA 

#0 

STA 

$43 

STA 

$45 

STA 

$47 

LDY 

$40 

JSR 

BRK 

MPADD 


;PLAZIERE STAPEL AN DAS ENDE VON 
SEITEI 

;BEWAHRE STARTADRESSE DER ERSTEN 
ZAHLAUF 

;BEWAHRE STARTADRESSE DER ZWEITEN 
ZAHL AUF 

;BEWAHRE STARTADRESSE DES 
ERGEBNISSES AUF 

;BEWAHRE SEITENNUMMER FÜR ALLE 
ADRESSEN AUF 


HOLE LÄNGE DER ZAHLEN IN BYTES 
ADDITION MIT MEHRFACHER GENAUIG¬ 
KEIT 


UNTERPROGRAMM MPADD (MULTI-PRECISION ADDITION) 

ZWECK: MPADD ADDIERT ZWEI MEHRWORT-BINÄRZAHLEN 

ANFANGSBEDINGUNGEN: STARTADRESSEN DER ZAHLEN INDEN 
SPEICHERPLÄTZEN 0042 UND 0043. 0044 UND 0045, 

STARTADRESSE DES ERGEBNISSES IN DEN SPEICHERPLÄTZEN 0046 UND 
0047. 

LANGE DER ZAHLEN IM INDEX-REGISTER Y 
VERWENDETE REGISTER: A, Y. ALLE FLAGS 

VERWENDET SPEICHERPLÄTZE: 0042, 0043, 0044, 0045. 0046, 0047, 
BEISPIEL: 

ANFANGSBEDINGUNGEN: 0048 IN 0042UND 0043, 

004C IN 0044 UND 0045, 0050 IN 0046 UND 0047, 

(Y) - 02, (0048)- A7, (0049) -Q C3. (0046)- 35, (004D) - B8 

ENDBEDINGUNGEN: (0050) - DD, (0051) - 7 B 


Das Unterprogramm führt die Binär-Addition mit mehrfacher Genauigkeit aus 
•- $20 


MPADD CLC 


iLÖSCHE ÜBERTRAG ZU BEGINN 

ADDB DEY 



LDA 

($42),Y 

;HOLE BYTE VON ERSTER ZAHL 

ADC 

($44), Y 

;ADDIERE BYTE VON ZWEITER ZAHL 

STA 

($46),Y 

SPEICHERE ERGEBNIS 

TYA 


;ALLE BYTES ADDIERT? 

BNE 

ADDB 

;NEIN, SETZE FORT 

RTS 
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Objektprogramm: 



Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 


Befehl 

(Mnemonik) 

1) 

Aufrufendes Programm 






0000 

A2 


LDX 

#$FF 


0001 

FF 





0002 

9A 


TXS 



0003 

A9 


LDA 

#$48 


0004 

48 





0005 

B5 


STA 

$42 


0006 

42 





0007 

A9 


LDA 

#$4C 


0006 

4C 





0009 

B5 


STA 

$44 


000A 

44 





OOOB 

A9 


LDA 

#$50 


OOOC 

50 





000D 

85 


STA 

$46 


000E 

46 





000F 

A9 


LDA 

#0 


0010 

00 





0011 

B5 


STA 

$43 


0012 

43 





0013 

B5 


STA 

$45 


0014 

45 





0015 

B5 


STA 

$47 


0016 

47 





0017 

A4 


ldy 

$40 


001B 

40 





0019 

20 


JSR 

MPADD 


001A 

20 





001B 

00 





001C 

00 


BRK 


2) 

Unterprogramm 






0020 

1B 

MPADD 

CLC 



0021 

BB 

ADDB 

dey 



0022 

Bl 


LDA 

($42).Y 


0023 

42 





0024 

71 


ADC 

($44I,Y 


0025 

44 





0026 

91 


STA 

($46).Y 


0027 

46 





002B 

96 


TYA 



0029 

DO 


BNE 

ADDB 


002A 

F6 





002B 

60 


RTS 



Dieses Unterprogramm besitzt vier Parameter - drei Adressen und die Länge 
der Zahlen. Für die Übergabe der Parameter werden sechs Speicherplätze auf 
Seite null und das Indexregister Y verwendet. 

Wie beim vorhergehenden Beispiel könnten wir den TYA-Befehl durch Neu¬ 
organisieren des Programmes eliminieren, oder durch Versetzen der Adressen- 
Parameter um 1. 
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AUFGABEN 


Beachten Sie, daß Sie sowohl das Aufruf-Programm für das Beispiel, als auch 
ein entsprechend dokumentiertes Unterprogramm schreiben sollen, 

1) ASCII in Hexadezimal 

Zweck: Wandle den Inhalt des Akkumulators von der ASCII-Darstellung einer 
Hexadezimal-Zifler In die tatsächliche Ziffer um. Plaziere das Ergebnis 
inden Akkumulator. 

Beispiele: 


a 

(A) - 

43 

ASCIIC 

Ergebnis: 

(A) - 

OC 


b. 

(A) - 

36 

ASCII 6 

Ergebnis. 

(A) - 

06 



2) Länge einer Femschreib-Nachricht 

Zweck: Bestimme die Länge einer ASCil-codierten Fernschreib Nachricht. Die 
Start Adresse der Zeichen-Reihe, in der die Nachricht eingebettet ist, 
liegt in den Speicherplätzen 0043 und 0043. Die Nachricht selbst be¬ 
ginnt mit einem ASCII-Zeichen STX (02i S ) und endet mit ASCII-ETX 
(03i S ). Plaziere die Länge der Nachricht (Anzahl der Zeichen zwischen 
dem STX und dem ETX) in den Akkumulator. 


Beispiel: 


(0042) 

(0043) 


^ | Startadresse der Reihe 


(0044) - 49 

(0045) - 02 STX 
(0046) - 47 'G' 
(0047) - 4F 'O' 
(0048) - 03 ETX 


Ergebnis: (A) - 02 
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3) Minimaiwert 


Zweck: Suche das kleinste Element in einem Block von Binärzahlen ohne 
Vorzeichen. Die Länge des Blocks liegt im Index-Register Y und die 
Startadresse des Blockes liegt in den Speicherplätzen 0040 und 
0041. Der Minimalwert wird in den Akkumulator zurückgelegt. 

Beispiel: 


(Y) - 05 Länge des Blockes 


(0040) 

(0041) 


43 T 

Q 0 > Startadresse des Blockes 


(0043) - 67 

(0044) - 79 
(0045) - 15 

(0046) - E3 
(0047) - 73 


Ergebnis: (A) - 15, da dies die kleinste von fünf Zahlen ohne 

Vorzeichen ist. 


4) Vergleich von Reihen 

Zweck: Vergleiche zwei Reihen von ASCII-Zeichen um lestzustellen, wel¬ 
che größer ist (d.h. welche der anderen in "alphabetischer” Reihen- 
lolge folgt). Die Länge der Reihen befindet sich im Index-Register 
Y, die Start-Adresse der Reihe 1 in den Speicherplätzen 0042 und 
0043, und die Start-Adresse der Reihe 2 In den Speicherplätzen 
0044 und 0045. Wenn Reihe 1 größer oder gleich wie Reihe 2 ist. 
lösche Akkumulator. Andernfalls setze Akkumulator auf FF, 8 - 
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Beispiele: 


a. 

(V) 


03 

Länge der Reihen 


(0042) 

(0043) 

=■ 

46 1 
00 j 

^ Slartadresse von Reihe 1 


(0044) 

(0045) 

= 

4A) 
00 J 

^ Staitadresse der Reihe 2 


(0046) 

= 

43 

C 


(0047) 

= 

42 

A 


(0048) 

= 

54 

T 


(004A) 

— 

42 

'B' 


(004B) 

- 

41 

’A' 


(004C) 

- 

54 

’T’ 

Ergebnis: 

(A) 


00, da 'CAT' "größer als 'BAT' ist 

b. 

(V) 


03 

Länge der Reihen 


(0042) 

(0043) 

= 

46) 

00j 

^ Slartadresse der Reihe 1 


(0044) 

(0045) 

- 

4 Al 

00 j 

• Slartadresse der Reihe 2 


(0046) 

— 

43 

’C‘ 


(0047) 

= 

41 

*A’ 


(0048) 


54 

’T' 


(004A) 


43 

'C' 


(004B) 

- 

41 

’A' 


(0040 


54 

T 

Ergebnis: 

(A) 


00, da die Reihen gleich sind 

c. 

(V) 

= 

03 

Länge der Reihen 


(0042) 

(0043) 

- 

461 

ooj 

» Slartadresse der Reihe 1 


(0044) 

(0045) 

= 

4A) 

og 

► Startadresse der Reihe 2 


(0046) 


43 

C' 


(0047) 

- 

41 

r A r 


(0048) 

— 

54 

T 


(004A) 

_ 

43 

C' 


(004B) 

= 

55 

U' 


(004C) 

= 

54 

T 

Ergebnis: 

(A) 

= 

FF, da 'CUT' "größer" als 'CAT isl 
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5) Dezimale Subtraktion 

Zweck: Subtrahiere eine Mehrwort-Dezimalzahl (BCD) von einer anderen 

L r 9 !, d Ti ahlen (ln By,es) bef 'ndel sich im Index-Register Y 
Un ^ JnL o a Il ^dressesn der Zahlen in den Speicherplätzen 0042 
und 0043, 0044 und 0045, Subtrahiere die Zahl mit der Start- 

md e nO 43 in n 004 Qi T d 0045 VOr der mit der Start-Adresse in 0042 
und 0043 Die Start-Adresse des Ergebnisses befindet sich in den 

wertiaen7 Ifern" °° h 47 h ” 6 Zahlen begir,nen mit de n höchst- 

ertigen Ziffern. Das Vorzeichen des Ergebnisses wird in den Akkumu- 

negahv is^ 96 69 " U ' Wenn das Resu,,al posi,iv ist - FF ’s. wenn es 


Beispiel: 


Ergebnis: 


(Y) 


04 

(0042) 

es 

48 

(0043) 


00 

(0044) 

— 

4C 

(0045) 

= 

00 

(0046) 

=9 

50 

(0047) 


00 

(0048) 


36 

(0049) 

- 

70 

(004A) 

- 

19 

(004B) 

= 

85 

(004C) 

= 

12 

(004D) 

= 

66 

(004E) 

= 

34 

(004F) 

= 

59 

(A) 


00 

(0050) 


24 

(0051) 

- 

03 

(0052) 

- 

85 

(0053) 

= 

26 


Länge der Zahlen in Bytes 

Startadresse des Minuenden 

Starladresse des Subtrahenden 

Startadresse der Dif erenz 

höchstwertige Stelle des Minuenden 

niedrigstwertige Stelle des Minuenden 
höchstwertige Stelle des Subtrahenden 

niedrigstwertige Stelle des Subtrahenden 
positives Ergebnis 

höchstwertige Stelle der Differenz 

niedrigstwertige Stelle der Differenz 


d.h. 36701985 
-12663459 
+ 24038526 
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Kapitel 11 

EINGABE/AUSGABE 


Es gibt zwei Probleme bei der Entwicklung von Eingabe/Ausgabe Anordnun¬ 
gen: Ein Problem besteht darin, wie periphere Bausteine an den Computer an¬ 
zupassen sind und wie Daten, Status und Stuersignale übertragen können. 
Das andere besteht im Adressieren der E/A-Bausteine, so daß die CPU einen 
speziellen hiervon für einen Datentransfer auswählen kann. Das erste Problem 
ist offensichtlich sowohl komplexer als auch interessanter. Wir wollen daher 
hier das Anpassen (Interfacing) von peripheren Geräten besprechen und die 
Adressierung einem mehr hardware-on'entierten Buch überlassen. 


Theoretisch ist der Transfer von Daten von oder zu einem 
E/A-Baustein ähnlich dem Transfer von Daten zu oder von 
einem Speicher. In der Tat können wir den Speicher wie 
jeden beliebigen anderen E/A-Baustein ansehen. Der Speicher unterscheidet 
sich jedoch von E/A-Bausteinen aus folgenden Gründen: 


E/A UND 
SPEICHER 


1 ) Er arbeitet meistens mit der gleichen Geschwindigkeit wie der Prozessor. 

2) Er verwendet die gleiche Art von Signalen wie die CPU. Die einzigen Schal¬ 
tungen, die gewöhnlich zur Anpassung des Speichers an die CPU benötigt 
werden sind Treiber, Empfänger und Pegelwandler. 

3) Er benötigt keine speziellen Formate oder irgendwelche Steuersignale aus¬ 
ser einem Schreib/Lese-impuls. 

4) Er speichert automatisch die ihm zugesandten Daten. 

5) Die Wortlänge ist die gleiche wie die des Computers. 


Die meisten E/A-Bausteine besitzen nicht derart bequeme Eigenschaften. Sie 

können bei Geschwindigkeilen arbeiten, die wesentlich niedriger als die des 
Prozessors sind. Zum Beispiel kann ein Fernschreiber nur 10 Zeichen pro Se¬ 
kunde übertragen, während ein langsamer Prozessor 10.000 Zeichen pro Se¬ 
kunde transferieren kann. Der Bereich der Geschwindigkeiten Ist also sehr 
breit, Sensoren können eine Ablesung pro Minute liefern, während Video-Anzei¬ 
gen oder Floppy-Disks 250.000 Bits pro Sekunde übertragen können. Ferner 
benötigen E/A-Bausteine des öfteren kontinuierliche Signale, (Motoren oder 
Thermometer), brauchen eher Strom statt Spannungen (Fernschreiber), oder 
Spannungen, die wesentlich andere Pegel als Signale, die der Prozessor ver¬ 
wendet (Gas-Enlladungs-Anzeigen) E/A-Bausteine können auch spezielle For¬ 
male, Übertragungs-Prozeduren oder Steuersignale benötigen. Ihre Wortlänge 
kann wesentlich kürzer oder wesentlich länger als die Wor:länge des Computers 
sein Alle diese Variationen bedeuten, daß die Entwicklung von E/A-Anordnun- 
gen schwierig Ist und jeder periphere Baustein seine eigenen speziellen An¬ 
passungs-Probleme besitzt. 


Wir können jedoch eine allgemeine Beschreibung von 
Bausteinen und Interfacing-Methoden geben. Wir können 
die Bausteine grob in drei Kategorien einteilen, basierend 
schwlndigkeiten: 


E/A- 

KATEGORIEN 


auf ihren Datenge- 
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1) Langsame Bausteine, die ihren Zustand nicht mehr als einmal pro Sekunde 
ändern. Die Änderung ihrer Zustände dauert typisch Millisekunden oder län¬ 
ger. Derartige Bausteine umfassen Leuchtanzeigen, Schalter, Relais und 
zahlreiche mechanische Sensoren und Betätigungsglieder. 

2) Bausteine mit mittlerer Geschwindigkeit, die Daten mit Geschwindigkeiten 
von 1 bis 10.000 Bits pro Sekunde übertragen. Derartige Bausteine umfas¬ 
sen Tastaturen, Drucker, Kartenleser, Lochstreifen-Leser und Stanzer, Kas¬ 
setten, gewöhnliche Übertragungsleistungen und zahlreiche analoge Daten¬ 
erfassungs-Systeme. 

3) Schnelle Bausteine, die Daten mit Geschwindigkeiten über 10.000 Bits pro 
Sekunde übertragen. Derartige Bausteine umfassen Magnetbänder, Magnet- 
platten, schnelle Zeilendrucker, Kommunikationsleitungen für hohe Ge¬ 
schwindigkeiten und Video Anzeigen. 


Die Anpassung von langsamen Bausteinen ist ein¬ 
fach. Es sind wenige Steuerbausteine erforderlich, 
mit Ausnahme für das Multiplexen, das heißt, die 
Bedienung mehrerer Bausteine von einem Port, wie 
in den Bilder 11-1 bis 11-4 gezeigt ist. Die Eingangs¬ 
daten von langsamen Bausteinen müssen nicht zwischengespeichert werden, 
da sie während langer Zeitintervalle stabil bleiben. Ausgangsdaten müssen na¬ 
türlich zwischengespeichert werden. Das einzige Problem bei der Eingabe sind 
die Übergänge, die auftreten, während der Computer die Daten liest. Monosta¬ 
bile Multivibratoren, kreuzgekoppelte Zwischenspeicher, oder Soltware-Verzö- 
gerungsroutinen können die Spannungsprünge glätten. 

Ein einzelner Port kann mehrere langsame Bausteine bedienen. Bild 11-1 zeigt 
einen Demultiplexer, der automatisch die nächsten Ausgangsdaten zum näch¬ 
sten Baustein dirigiert, indem er die Ausgabe-Operationen zählt. Bild 11-2 zeigt 
einen Steuerport, der Auswahl-Signal zu einem Demultiplexer liefert. Die Aus¬ 
gangsdaten können hier in jeder beliebigen Reihenfolge kommen, es ist jedoch 
ein zusätzlicher Ausgabebefehl erforderlich, um den Zustand des Steuerports 
zu ändern. Ausgangs Demultiplexer werden gewöhnlich zur Steuerung mehre¬ 
rer Anzeigen vom gleichen Ausgangsport verwendet. Die Bilder 11-3 und 11-4 
zeigen die gleichen Alternativen für einen Eingangs-Multiplexer. Beachten Sie 
den Unterschied zwischen Eingabe und Ausgabe bei langsamen Bausteinen: 

1) Eingangsdaten müssen nicht gespeichert werden, da der Eingangs-Bau¬ 
stein die Daten für eine außerordentlich lange Zeit aufbewahrt, verglichen mit 
den bei Computer üblichen Zeiten. Ausgangsdaten müssen zwischengespei¬ 
chert werden, da der Ausgang-Baustein nicht auf Daten reagieren wird, die 
nur während einiger weniger CPU-Taktzyklen vorliegen. 

2) Eingangs-Spannungssprünge können infolge ihrer Dauer Probleme verur¬ 
sachen. Kurze Ausgangs-Spannungssprünge bewirken keine Probleme, da 
die Ausgangs-Bausteine (oder die Beobachter) langsam reagieren. 

3) Die wichtigsten Einschränkungen bei der Eingabe sind die Reaktionszeit 
und die Empfindlichkeit. Die wesentlichsten Einschränkungen bei der Aus¬ 
gabe sind die Reaktionszeit und Erkennbarkeit. 


Bausteine mit mittlerer Geschwindigkeit müssen 
auf irgendeine Weise mit dem Prozessor-Takt 
synchronisiert werden. Die CPU kann nicht ein¬ 
fach diese Bausteine so behandeln, als ob sie 
ihre Daten für immer behalten oder Daten zu ie- 
der Zeit empfangen könnten. Stattdessen muß die CPU imstande sein zu be¬ 
stimmen, wann ein Baustein neue Daten eingegeben hat oder wann er bereit ist, 
Ausgangsdaten zu empfangen. Sie muß auch eine Möglichkeit besitzen, einem 
Ausgangs-Baustein mitzuteilen, daß neue Daten verfügbar sind, oder daß die 
vorhergehenden Eingangsdaten angenommen worden sind Beachten Sie, daß 
das periphere Gerät ein anderer Prozessor sein oder einen Prozessor enthalten 
kann. 

Das standardisierte, nicht getaktete Verfahren ist die Quit¬ 
tierung (Handshake). Hier zeigt der Sender dem Empfänger 
die Verfügbarkeit von Daten an und überträgt dann die Daten. Der Empfänger 
vervollständigt die Quittierung, indem er den Empfang der Daten bestätigt. Der 
Empfänger kann die Situation steuern, indem er anfangs Daten anfordert oder 
indem er seine Bereitschaft zum Empfang von Daten anzeigt. Der Sender 
schickt dann die Daten und vervollständigt die Quittierung durch Anzeige, daß 
die Daten verfügbar sind. In jedem Fall weiß der Sender, daß der Transfer er¬ 
folgreich abgeschlossen wurde und der Empfänger weiß, wann die Daten ver¬ 
fügbar sind. 


ANPASSUNG VON 

LANGSAMEN 

BAUSTEINEN 


ANPASSUNG VON 
BAUSTEINEN MIT 
MITTLERER 
GESCHWINDIGKEIT 


QUITTIERUNG 


11-2 


1 1-3 







Bild 11-1. Ein Ausgangs-Demultiplexer, gesteuert von einem Zähler 



Dalen- 

fingÄnge 




Au watil- 
Eingänge 


Die CPl) endet die Steueriniormahon zucn Steuerport. Dieser Port bestimmt 
wohin der Demultiplexer die Daten sendet 


Bild 11-2, Ein Ausgangs-Multiplexer, gesteuert von einem Port, 



Bild 11-3. Ein Eingangs Multiplexer, gesteuert von einem Zähler, 



aten- 

Ausgänge 



Auswahl 

Eingänge 


Die Steuerinformation, die die CPU zum Sleuerport sendet (mit einer Ausgabe- 
Operation) bestimmt, welchen Eingang der Multiplexer zum Datenpoit fühlt. 


Bild 11-4. Ein Eingangs-Multiplexer, gesteuert von einem Port. 
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Die Bilder 11-5 und 11-6 zeigen typische Eingabe- und Ausgabe-Operationen, 
die das Quittierungs-Verfahren verwenden. Das Verfahren, bei dem die CPU die 
Bereitschaft des peripheren Bausteines vor dem Transfer der Daten prüft, wird 
"polling" ("Abfragen") genannt. Offensichtlich kann das "polling" einen großen 
Teil der Prozessorzeit belegen, wenn mehrere E/A-Bausteine vorhanden sind. 
Es gibt mehrere Arten, wie die Ouittierungs-Signale zur Verfügung gestellt 
werden. Einige hiervon sind: 


• Seperate bestimmte E/A-Leitungen. Der Prozessor kann diese als zusätzli¬ 
che E/A-Ports handhaben oder durch spezielle Leitungen oder Unterbre¬ 
chungen. Der Prozessor 6502 besitzt keine seriellen E/A Leitungen. Es sind 
jedoch derartige Leitungen beim peripheren Interface-Adapter (oder PIA) 
6502 verfügbar, sowie beim Versatile Interface-Adapter (oder VIA) 6522 und 
dem peripheren Interface/Speicher (oder Mehrfunktions)-Baustein 6532. 

• Spezielle Muster auf den E/A-Leitungen. Dies können einfache Start- und 
Stop-Bits oder ganze Zeichen oder Zeichengruppen sein. Die Muster müs¬ 
sen leicht vom Hintergrund-Rauschen oder inaktiven Zuständen zu unter¬ 
scheiden sein. 


T AST-IMPULS 


Wir nennen häufig eine seperate E/A-Leitung, die die Ver¬ 
fügbarkeit von Daten oder das Auftreten einer Übertra¬ 
gung anzeigt, eine "Tastleitung” (Strobe). Ein Tastleitung kann beispielsweise 
Daten in einen Zwischenspeicher takten oder Daten von einem Pufferholen. 


Zahlreiche periphere Bausteine transferieren Daten in gleichmäßigen Interval¬ 
len, das heißt synchron. Das einzige Problem besteht hier im Starten des Vor¬ 
gangs, indem die erste Eingabe richtig angeordnet wird oder die erste Aus¬ 
gabe markiert wird, in einigen Fällen liefert der periphere Baustein ein Takt- 
Signal, von dem der Prozessor Informationen für die zeitliche Steuerung erhal¬ 
ten kann. 


Übertragungsfehler sind ein Problem bei Bau¬ 
steinen mit mittlerer Geschwindigkeit. Mehrere 
Verfahren können die Wahrscheinlichkeit derar¬ 
tiger Fehler verringern. Sie beinhalten: 

• Abtasten der Eingangsdaten in der Mitte des Übertragungs-Intervalls, um 
Rand-Effekte zu vermeiden. Das heißt, einen Abstand zu den Enden zu hal¬ 
ten. bei denen sich die Daten ändern. 

• Abtasten jeder Eingabe mehrere Male und Verwendung einer Majoritäts- 
Logik, wie etwa "Bestthree out of five" 1 (etwa "die besten drei aus fünf") 

• Erzeugung und Prüfung der Parität. Ein zusätzliches Bit wird verwendet, das 
die Zahl der 1-Bits in den korrekten Daten gerade oder ungerade macht. 

• Verwendung anderer Fehlerpriif- und Korrekturcodes, wie etwa Prüfsum¬ 
men, LRC (longitudinal reduncy check - longitudinale Redundanz Prüfung) 
und CRC (cyclic redundancy check= Zyklische Redundanz-Prüfung). 2 


VERRINGERUNG VON 
ÜBERTRAGUNGS¬ 
FEHLERN 


Bausteine mit hoher Geschwindigkeit, die mehr 
als 10.000 Bits pro Sekunde übertragen, benöti¬ 
gen spezielle Verfahren. Die allgemeine Technik be¬ 
steht im Aufbau eines speziellen Steuergerätes, das 
Daten direkt zwischen dem Speicher und dem E/A- 
Baustein transferiert Dieser Vorgang wird direkter 
Speicherzugriff (DMA - direct memory access) ge¬ 
nannt. Das DMA-Steuergerät muß die CPU von den Bussen fernhalten, Adres¬ 
sen und Steuersignale für den Speicher liefern und die Daten transferieren. Ein 
derartiges Steuergerät ist ziemlich komplex und besteht gewöhnlich aus 50 bis 
100 Chips, obwohl nunmehr LSI-Bausteine erhältlich sind. Die CPU muß an¬ 
fangs die Adresse und den Datenzähler in das Steuergerät laden, so daß das 
Steuergerät weiß, wo es zu beginnen hat und wieviel zu übertragen ist. 


ANPASSUNG VON 
BAUSTEINEN MIT 
HOHER 

GESCHWINDIGKEIT 


DIREKTER 

SPEICHERZUGRIFF 
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Ectgangs- 

bestabguog 



Petighe^s 

Gerät 


a) Das periphere Gerät liefert Daten und das Signal Daten bereit" «um E/A-Abschnitt des Computers 


Eingangs¬ 

bestätigung 


E/A- 

Atwctvnitt 


Periphere« 

Gerät 


b) Die CPU liest das Signal "Daten bereit" vom E/A-Abschmtt (dies kann eine Hardware- 
Unterbrechung sein) 


Eingangs 
be stefcgung 



c) Die CPU liest die Daten vom E/A-Abschnitt. 


Eingangs- 
I bestatigung 


I 


e/A . 


Peripheres 

Gerät 



ffe<%JherF& 

Gerät 




d) Die CPU sendet das Signal & ngabe-Qest a^Oung 1 * aum E/A-Atxschnitl, der dann ein Signa 
Eingabe-Bestätigung“ zum peripheren Gerät liefert (dies kann eine Hardware-Verbindung sein) 
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a) Peripheres Gerät liefert ein Signal "Peripheres Gerät bereit” zum E/A-Abschnitt des Computers 



b) Die CPU liest das Signal Peripheres Gerät bereit" vomE/A-Abschnitt (dies kann eine Hardware- 
Unterbrechungs-Verbindung sein). 




Ausgabe 





betet! 








Datenbus 

E/A- 

AtocJüMl 

Daten 

Oerel 

CPU 


j 



Peripheres 
Gerat bereit 











Q) Die CPU sendet Daten zum peripheren Gerät 



d) Die CPU »endet des S gnel Ausgabe bereit” zum peripheren Gerät (dies kann eine Haidware 
d/bindung sein) 


Bild 11 -6 Eine Ausgabe-Quittierung. 









Zeit-Intervalle (Verzögerungen) 


Verzögerungs-Routinen 


Eine Aufgabe, der wir während der Besprechung 
der Eingabe/Ausgabe begegnen werden, ist die 
Erzeugung von Zeit-Intervallen mit bestimmten 
Längen. Derartige Zeit-Intervalle sind erforderlich, um mechanische Schalter zu 
entprellen (um ihre unregelmäßigen Spannungssprünge zu glätten). Impulse mit 
speziellen Längen und Frequenzen für Anzeigen zu liefern, sowie zeitliche 
Steuerung für Bausteine zu liefern, die Daten gleichmäßig transferieren (bei¬ 
spielsweise ein Fernschreiber, der ein Bit alle 9.1 ms sendet oder empfängt). 


Wir können Zeft-Intervalle auf verschiedene Arten 

erzeugen: 

1) Mit Hardware mit monostabilen Multivibrato¬ 
ren. Diese Bausteine erzeugen einen einzelnen 
Impuls fester Länge, als Reaktion auf einen Eingangs-Impuls, 

2) Mit einer Kombination von Hardware und Software mit einem flexiblen, pro¬ 
grammierbaren Zeitgeber, wie jene, die im Versatile Interface Adapter 6522 
(der später in diesem Kapitel beschrieben wird) enthalten sind. Die Zeitgeber 
des 6522 können Zeit-Intervalle unterschiedlicher Länge mit einer Vielzahl 
von Start- und Stop-Bedingungen liefern. 3 

3) Mit Software durch Verzögerungs-Routinen. Diese Routinen verwenden den 
Prozessor als Zähler Dies ist möglich, da der Prozessor einen stabilen 
Referenz Takt besitzt, wobei jedoch offensichtlich der Prozessor nicht wirt¬ 
schaftlich verwendet wird. Diese Verzögerungs-Routinen benötigen jedoch 
keine zusätzliche Hardware und verwenden Prozessor-Zeit, die sonst unge¬ 
nutzt wäre. 


Die Auswahl eines dieser drei Verfahren hängt 
von ihrer Anwendung ab. Das Software-Verfahren ist 
preisgünstig, kann jedoch den Prozessor überlasten. 

Die programmiebaren Zeitgeber sind relativ teuer, 
aber leicht anzupassen und imstande, zahlreiche 
komplexe Aufgaben für die zeitliche Steuerung zu handhaben. Die Zeitgeber, 
die im Versatile Interface-Adapter 6522 und in den Mehrt unktions-Bausteinen 
6503 und 6532 enthalten sind, sind ohne zusätzliche Kosten verfügbar, wenn 
diese Bausteine verwendet werden. Diese Teile können etwas teurer als einfa¬ 
che Bausteine sein, sind jedoch als vollständige Gehäuse vertretbar. Derartige 
Telle mit integrierten Zeitgebern werden in zahlreichen Ein-Platin-Mikrocompu- 
tern verwendet, einschließlich des KIM, SYM, VIM und AIM-65. Die Verwendung 
von monostabilen Multiviratoren sollte wenn immer möglich vermieden werden. 


AUSWAHL EINER 
METHODE FÜR 
DIE ZEITLOSE 
STEUERUNG 


METHODEN FÜR DIE 
ERZEUGUNG VON 
ZEIT-INTERVALLEN 


VERWENDUNG VON 
ZEIT-INTERVALLEN 


Eine einfache Verzögerungs-Routine arbeitet wie 
folgt: 

Schritt 1) Lade ein Register mit einem spezifizier¬ 
ten Wert. 

Schritt 2) Dekrementiere das Register, 

Schritt 3) Wenn das Ergebnis von Schritt 2 nicht null ist, wiederhole Schritt 2. 

Diese Routine macht nichts we rter, als Zeit benötigen. Der Bertrag der verwen¬ 
deten Zeit hängt von der Auslührungszeit der verschieden Befehle ab. Die maxi¬ 
male Länge der Verzögerung ist durch die Größe des Registers begrenzt. Die 
gesamte Routine kann jedoch in eine ähnliche Routine plaziert werden, die ein 
weiteres Register verwendet, usw. 

Seien Sie sorgfältig - die tatsächlich verwendete Zeit hängt von der Taktrate 
ab, mit der der Prozessor läuft, der Geschwindigkeit des Speicherzugriffes und 
den Betriebs-Bedingungen wie Temperatur, Betriebsspannung und Belastung 
der Schaltung, die die Geschwindigkeit beeinflussen kann, mit der der Prozes¬ 
sor Befehle ausführt. 


Das folgende Beispiel verwendet dte Indexregi¬ 
ster X und Y zur Lieferung von Verzögerungen bis 

zu 255 ms. Die Wahl der Register ist willkürlich. Viel¬ 
leicht finden Sie auch, daß die Verwendung des 
Akkumulators oder von Speicherplätzen bequemer ist. Erinnern Sie sich jedoch 
daran, daß der 6502 keinen ausdrücklichen Befehl zum Dekrementieren des Ak¬ 
kumulators besitzt. Wir könnten eine Routine bilden, die den Inhalt irgendeines 
Anwender-Registers nicht ändert. Die Sequenz 

PHP ;BEWAHRE STATUSREGISTER AUF 

PHA ;BEWAHRE AKKUMULATOR AUF 

TXA ;BEWAHRE INDEXREGISTER X AUF 

PHA 

TYA iBEWAHRE INDEXREGISTER Y AUF 

PHA 

würde den Inhalt aller Register zu Anfang aufbewahren und die Sequenz 

PLA ;SPEICHERE INDEXREGISTER Y ZURÜCK 

TAY 

PLA iSPEICHERE INDEXREGISTER X ZURÜCK 

TAX 

PLA ;SPEICHERE AKKUMULATOR ZURÜCK 

PLP iSPEICHERE STATUSREGISTER ZURÜCK 

würde die Register am Ende der Routine zurückspeichern. Ein Unterprogramm, 
daß keinerlei Register oder Flags beeinflußt, wird "transparent" für das auf¬ 
rufende Programm genannt. Die Befehlssequenzen, die die Register aufbewah- 
en und zurückspeichern, müssen natürlich in dem Zeitbudget enthalten sein. 


TRANSPARENTE 

VERZÖGERUNGS¬ 

ROUTINE 


GRUNDLEGENDE 

SOFTWARE¬ 

VERZÖGERUNG 
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Verzögerungsprogramm: 

Zweck: Das Programm liefert eine Verzögerung von 1 ms mal dem Inhalt von 
Index-Register Y. 

Flußdiagramm: 



Oer Wert von MSCN hängt von der 
Geschwindigkeit der CPU und 
den) Speicherzykius ab. 


Quellprogramm: 


DELAY 

LDX 

#MSCNT 

DLY1 

DEX 



BNE 

DEY 

DLY1 


BNE 

RTS 

DELAY 


HOLE DIE ZÄHLUNG FÜR IMS- 
VERZÖGERUNG 
ZÄHLUNG =ZÄHLUNG-1 
SETZE FORT BIS ZÄHLUNG =■ 0 
DEKREMENTIERE ANZAHL DER VERBLEI¬ 
BENDEN MS 

SETZE FORT BIS ANZAHL DER MS = 0 


Objektprogramm: (beginnend im Speicherplatz 0030) 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 


Befehl 

(Mnemonik) 

0030 

A2 

DELAY 

LDX #MSCNT 

0031 

MSCNT 



0032 

CA 

DLY1 

DEX 

0033 

DO 


BNE DLY1 

0034 

FD 



0035 

88 


DEY 

0036 

DO 


BNE DELAY 

0037 

F8 



0038 

60 


RTS 


Zeit-Budget: 



Befehl 

LDX 

DEX 

#MSCNT 

BNE 

DEY 

DLY1 

BNE 

RTS 

DELAY 


Anzahlder Ausführungen 
(Y) 

(Y) x MSCNT 
(Y) x MSCNT 
(Y) 

(Y) 

1 


Die gesamte verwendete Zeit sollte gleich (Y) x 1 ms sein. Wenn der Speicher 
mit voller Geschwindigkeit arbeitet, so benötigen die Befehle die folgenden 
Anzahl von Taktzyklen: 

Ignorieren der Seitengrenzen 


LDX 

#MSCNT 

2 oder 3 

2 

DEX 

oder DEY 

2 

2 

BNE 


2.3 od. 4 

2oder3 

RTS 


6 

6 


Die alternativn Zeiten für LDX # MSCNT hängen davon ab, ob eine Seitengren¬ 
ze überschritten wird. Die alternativen Zeiten für BNE hängen davon ab, ob die 
Verzweigung auftritt oder nicht (2), zu einer Adresse auf der gleichen Seite auf- 
tritt (3). oder zu einer Adresse auf einer anderen Seite auftritt (4). Eine Seile stellt 
einen Satz 256 aufeinanderfolgenden Speicherplätzen dar, die die gleichen acht 
höchstwertigen Bits (oder Seitennummer) in ihren Adressen besitzen. Wir wollen 
annehmen, daß die Routine so liegt, daß keine Seitengrenzen überschritten wer¬ 
den und wir können die rechte Spalte der letzten Tabelle für die Bestimmung 
der Zeit verwenden. 

Wenn die Befehle Jump-to-Subroutine (JSR) und Return-from-Subroutine (RTS) 
ignoriert werden (die nur einmal auftreten), benötigt das Programm: 

(Y) x (2 + 5 x MSCNT - 1 + 5) -1 Taktzyklen 

Die Terme -1 werden durch die Tatsache bewirkt, daß der BNE-Befehl weniger 
Zeit während der letzten Wiederholung benötigt, wenn der Zähler Null erreicht 
hat und keine Verzweigung auftritt. 

Und daher die Verzögerung ein 1 ms lang zu machen ist 
5 + 5 x MSCNT = N c , 

wobei Nc die Anzahl der Taktzyklen pro Millisekunde ist. Bei einer Standard- 
Taktrate von 1 MHz des 6502, Nc= 1000 ist daher: 

5 x MSCNT-995 

MSCNT - 199 (C7 18 ) bei einer Taktrafe von 1 
MHz des 6502. 


6502 VERZÖGE- 

GERUNGS-SCHLEI- 

FEN-KONSTANTE 
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Eingabe/Ausgabe-Chips des 6502 


Die meisten Eingabe/Ausgabe-Abschnitte des 6502 basieren auf LSI-lnter- 
face-Chips Diese Bausteine kombinieren Zwischenspeicher, Puffer, Flipflops 
und andere Logikschaltungen, die für einen Q«i»tierungsbetneb undI andere 
einfache Interface-Verfahren erforderlich sind. Sie enthalten zahlreiche Logik 
Verbindungen, wovon bestimmte Sätze entsprechend des ’ nh f( te ® 
grammierbaren Registern ausgewählt werden können. Der ^ ^ 

her eine Art Äquivalent einer 'Schaltungssammlung zur Verfügung. 0,e Init 
alisierungsphase des Programmes plaziert die 

ster, um die erforderlichen Logikverbindungen auszuwahlen. Ein Eingabe/Aus 
aabe-Abschnitt, der auf programmierbaren LSI-lnterface-Chips basiert, kann 
zahlreiche unterschiedliche Anwendungen verarbeiten und Änderungen oder 
Korrekturen können mittels Software ausgefuhit werden, anstatt durch eine 
neuerliche Verdrahtung. 


Wir werden die folgenden 

prozessor6502 verwendet 


LSI-lnterface-Chips besprechen, die 

werden können: 


mit dem Mikro- 


1) Der periphere Interface-Adapter 6520. Dieser Baustein enthält zwei■ B-Bit- 
' E/A-Ports und vier individuelle Steuerleitungen und entspricht genau dem 

6620, der mit dem Mikrocomputer 6600 verwendet wird.“ 

2) Der Versatile Interface-Adapter (Vielseitige Interface-Adapter 6522 . Die¬ 
ser Baustein enthält zwei 8-Bit-E/A-Ports, vier individuelle Steuerleitungen. 
zwei 16-Bit-Zähler/Zeitgeber und ein 6 Bit-Schieberegister 

3) Der periphere Interface/Speicher oder Mehrfunktions (H^fs) -Baustein 
’ 6530." Dieser Baustein enthält zwei 6-Bit-E/A-Ports einen 6 Bit-Zahler/- 

Zeitgeber mit einem Vorteiler. 1024 Bytes ROM und 54 Bytes RAM 

4) Oer periphere Interface/Speicher- oder Mehrfunktions (Hifs)-Bauste n 
6532. Dieser Baustein enthält zwei 6-Bit-E/A-Potts. einen 6-Bit-Zahler/Zeit 
geber mit einem Vorteiler und 126 Bytes RAM 

Die folgenden Abkürzungen werden häufig bei der Beschreibuing d'eser ßau- 
Cteine verwendet: Der 6520 PIA. 6522 VIA und der 6530 und 6532 RtOT (tur 

ROM oder RAM, I/O, und Timer-Kombination) Unsere E/A-Beispie^die spat 

in diesem Kapitel behandelt werden, werden alle den VIA 6522 verwenden, 
spiele für die Anwendung des Bausteines 6520 können in dem Buch 6600 
grammieren in Assembler"» gefunden werden, wobei diese ^ ei | p ' e '? . e ^ 
den 6502 Mikroprozessor adaptiert werden können (ennnern Sie sich an die 
Vergleiche in den Befehlssätzen in Tabelle 3-6 und 3-7). 
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Der periphere Interface-Adapter (PIA) 6520 


Bild 11-7 zeigt das Blockschaltbild eines PIA. Der Baustein enthält nahezu 
identisch 8-Bit-Ports: A, der gewöhnlich als Eingangs-Port dient, und B, der ge¬ 
wöhnlich als Ausgangs-Port arbeitet. Jeder Port enthält: 


• Ein Daten- oder Peripherie-Register, das entwe- PIA-REGISTER UND 
der Eingangs- oder Ausgangs-Daten aufbewahrt. STEUERLEITUNGEN 

Dieses Register arbeitet im Speicherbetrieb, wenn 

es für eine Ausgabe veiwendet wird, jedoch nicht im Speicherbetrieb, wenn 
es für eine Eingabe dient. 

• Ein Daten-Richtungsregister. Die Bits in diesem Register bestimmen, ob die 
entsprechenden Datenregister-Bits (und Anschlüsse) Eingänge (0) oder Aus¬ 
gänge (1) sind. 

• Ein Steuer-Register, das die Status-Signale aufbewahrt, die für den Quittie¬ 
rungsbetrieb eifo. r derlich sind, sowie andere Bits, die die Logik-Verbindun¬ 
gen innerhalb des PIA auswählen. 

• Zwei Steuerleitungen, die durch die Steuer-Register konfigurieit werden. 

Diese Leitungen können für die Quittierungs-Signale verwendet werden, wie 
in den Bildern 11-5 und 11-6 gezeigt ist. 

Die Bedeutung der Bits im Datenrichtungs-Register und den Steuer-Registern 
bezieht sich auf die entsprechende Hardware und ist völlig willkürlich, soweit es 
den Programmierer für die Assemblersprache betrifft. Man muß sie entweder im 
Gedächtnis behalten oder kann sie in den entsprechenden Tabellen (Tabellen 
11-2 bis 11-6) nachschlagen. 

Jeder PIA belegt vier Speicher-Adressen. Die RS (Register PIA-ADRESSEN 

Select - Registerauswahi)-Leitungen wählen eines der vier 
Register aus, wie in Tabelle 11-1 beschrieben ist. Da es in jedem PIA sechs Re¬ 
gister gibt (zwei periphere, zwt i Datenrichtungs-Register und zwei Steuer-Regi¬ 
ster), ist ein weiteres Bit für die Adressierung erforderlich. Bit 2 jedes Steuer- 
Registers bestimmt, ob sich die andere Adresse auf dieser Seite auf das Daten¬ 
richtungs-Register (0) oder das Peripherie-Register (1) bezieht. Diese gemein¬ 
same Verwendung einer externen Adresse bedeutet, daß: 

1) Ein Programm das Bit im Steuer-Register ändern muß, um das Register zu 
verwenden, das momentan nicht adressiert wird. 

2) Der Programmierer muß den Inhalt des Steuer-Registers kennen, um zu wis¬ 
sen, welches Register adressiert wird. RESET löscht das Steuer-Register und 
daher die Adressen im Datenrichtungs-Register. 

Tabeile 11-1. Adressierung der internen Register des PlA 5620. 


Adresetn-Lectunsen 

Steuer-Register-Bit 


RS1 

RSO 

CRA-2 

cub-z 

Audgüwihlte Ro^lettif 

c 

0 

1 

X 

Peripheral Register A (Peripheres Register A) 

0 

0 

0 

X 

Data Direction Register A 
(Datenrichtungs-Register A) 

0 

1 

X 

X 

Conlrol Register A (Steuer-Register A) 

1 

0 

X 

1 

Peripherat Register B (Peripheres Register B) 

1 

0 

X 

0 

Data Direction Register B 
(Datenrichtungs-Register B) 

1 

1 

X 

X 

Control Register B (Steuer-Register B) 


X- Entweder 0 oder 1 


11-15 







Bild 11-7. Blockschaltbild des Peripheren Interface-Adapters 6820. 
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PIA-Steuer-Register 

Tabelle 11-2 zeigt die Organisation der PIA- 
Steuer-Register. Wir können den allgemeinen 
Zweck jedes Bits wie folgt beschreiben: 

Bit 7: Status-Bit, gesetzt durch Übergänge auf der Steuerleitung 1 und gelöscht 
durch Lesen des Peripherie-(Daten-)Registers. 

Bit 6: Gleich wie Bit 7 mit Ausnahme, daß es durch Übergänge auf der Steuer¬ 
leitung 2 gesetzt wird. 

Bit 5: Bestimmt, ob die Steuerleitung 2 ein Eingang (0) oder Ausgang (1) ist. 

Bit 4: Eingang Steuerleitung 2: Bestimmt, ob Bit 6 durch High-auf-LOw-Über- 
gänge (0) oder Low auf-High-Übergänge (1) auf der Steuerleitung 2 ge¬ 
setzt wird. 

Ausgang Steuerleitung 2: Bestimmt, ob Steuerleitung 2 ein Impuls (0) 
oder ein Pegel(1)ist. 

Bit 3: Eingang Steuerleitung 2: Wenn 1, gibt Unterbrechungs-Ausgang von 
Bit 6 frei. 

Ausgang Steuerleitung 2: Bestimmt Endbedingung für Impuls (0 - Quit¬ 
tierungs-Bestätigung, dauert bis zum nächsten Übergang auf der 
Steuerleitung 1,1= kurzer Tast-Impuls, der einen Takt-Zyklus dauert) 
oder Wert des Pegels. 

Bit 2: Wählt Datenrichtungs-Register(O) oder Datenregister (1) aus. 

Bit 1: Bestimmt, ob Bit 7 durch High-auf-Low-Übergänge (0) oder Low-auf- 
High-Übergänge (1)auf der Steuerleitung 1 gesetzt wird. 

Bit 0: Wenn 1, gibt Unterbrechungs-Ausgang von Bit 7 des Steuer-Registers 
frei. 

Die Tabelle 11-3 bis 11-6 beschreiben die Bits detaillierter. Da E normalerweise 
zum 02-Takt geführt wird, kann man den "E"-Impuls als "Takt-Impuls" inter¬ 
pretieren. 


Tabelle 11 -2. Organisation der PIA-Steuer-Register 
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Tab. 11 -3. Steuerung der Unterbrechungs-Eingänge CA1 u. CA2 des PIA 6520 


CRA-1 

(CRB-1) 

CRA-0 

(CRB-0) 

Unterbrechungs- 

Eingang 

CA1 (CB1) 

Unterbrechungs- 

Flag 

CRA-7 (CRB-7) 

MPU-Unlerbrechungs- 

Anlorderung 

!R5Ä(iHOB) 

B 

0 

i Aktiv 

High gesetzt bei l von CA1 
(CB1) 

Freigegeben - IRQ 
blei bt High 

1 

■ 

; Aktiv 

High gesetzt bei l von CAI 
(CBt) 

Gehl auf Low, wenn das 
Unterbrechungs-Flag-Bil 

CRA-7 (CRB-7) auf High 
geht 

B 

0 

t Aktiv 

High gesetzt bei | von CAI 
(CB1) 

Freigegeben - IRQ 
bleibt High 

1 

1 

f Aktiv 

High gesetzt bei Ivon CAI 
(CB1) 

Gehl auf Low. wenn das 
Unlerbrechunga-Flag-Bil 

CRA-7 (CRB-7) auf High 
geht 


Anmerkungen: 

1. t zeigl einen positiven Übeigang an (Low auf High) 

2 1 zeigl einen negativen Übergang an iHiöb auf Low) 

3. Das Unlerbrechungs-Fiag-Bit CRA-7 wodurch ein MPU-Lesen das Datenreg.slers A 
gelöscht, undCRB-7 wird durch ein MPU-Lesen des DaleiV'eflisters B gelöscht. 

4, Wenn CRA-0 (CRB-0) beim Auftreten e iner Unterbre chung Low ist (Unterbrechung gesperrt) 
und später aut High gebracht wird. Irin IRQA (iRQB) aut. nachdem CRA-0 (CRB-0) aut 
"Eins” geschrieben wurde. 


Tab 11-4 Steuerung der Unterbrechungs-Eingänge CA2 u. CB2 des PIA 6520. 


CRA-5 ' 
(CRB-5) 

CRA4 

(CRB-4) 

CRA-3 

(CRB-3) 

Unterbrechungs- 
Eingang 
CRA-7 (CRB-71 

Unterbrechungs- 

Flag 

CAI (CB1) 

MPU-Unterbrechungs- 
Anforderung 
ifSSS (IRQB) 

B 

■ 

■ 


High gesetzt bei I von CA2 
(CB2) 

Freigegeben - IRQ 
bleibt High 


1 

1 

. Aktiv 

Highgesetzt bei i von CA2 
(CB2) 

Geht auf Low. wenn das 
Unlerbrechungs-Ftag-Bil 
CRA-6 (CRB-6) auf 

High geht 


■ 


t Aktiv 

High gesetzt bei T von CA2 
(CB2) 

Freigegeben - IRU 
bleibt High 

I 

■ 

■ 

T Aktiv 

High gesetzt bei t von CA2 
(CB2) 

Gehl aul Low, wenn das 
Unterbrechungs-Flag-Bit 
CRA-6 (CRB-6) aut 

High gehl 

Anmeikunge 

1 zeigt er 

2, ] zeigl ei 

3 OasUnle 
gelöscht 

4 Wenn CF 
und spät 
"Eins" g 

n: 

nen posil 
nennega 
rbrechur 
undCBF 
*A-3 (CR 
er aut Hi$ 
esclirieb 

wen Übergang an (Low auf High) 
liven Übergang a n (High auf Low) 

gs-Flag-BilCRA-6 wird durch ein MPU-Lesen des Oatenregisters A 

1-6 wird durch ein MPU-Lesen des DatenregistersB gelöscht. 

3-3) beim Auftreten emer Unterbrechung Low ist (Unterbrechung gesperrt) 
jb gebracht wird, tritt IW35 (IHÖB) auf. nachdem CRA-3 (CRB-31 auf 

Bn wurde. 


Tabelle 11 -5. Steuerung der CB2-Ausgangs-Leitung des PIA 6520 


CRB-5 

CRB-4 

CRB-3 

CE 

32 

Gelöscht 

Gesetzt 

1 

1 


Low beim positiven Übergang des 
ersten E-tmpulses.deremer MPU- 
Schreib-Operation des "B"-Daten- 
Regislers folgt 

High, wenn das Unterbrechungs- 
Flag-Bil CRB-7 durch einen akti¬ 
ven Übergang des CBl-Signais 
gesetzt wird. 

1 

0 

1 

Low beim positiven Übergang des 
ersten E-tmpu)ses nach einer MPU- 
Schreib-Operalion des "B"-Daten- 
Registers. 

High an der positiven Flanke des 
ersten '*E"-lmpulses. der einem 

E"-Impuls folgt, der 
auflral. während das Teil nicht 
gewählt war 

1 

1 

0 

Low. wenn CRB-3 auf Low gehl, als 
Ergebnis eines MPU-Schreibens in 
das Steuer-Register ’ B". 

Immer Low, so lange CRB-3 Low 
ist. Wird bei einem MPU-Schreiben 
in das Steuer-Register "B’ auf 

High gehen, das CRB-3 auf 
"Eins"ändert 

1 

1 

1 

Immer High, so lange CRB-3 High ist. 
Wird gelöscht, wenn ein MPU- 
Schreiben des Steuer-Registers "B" 
in einemLöschenvon CRB-3 auf 
"null" resultiert. 

High, wenn CRB-3 auf High geht, 
als Ergebnis einesMPU- 
Schreibens in das Steuer- 
Register "0", 


Tabelle 11-6. Steuerung der CA2-Ausgangs-Leitung des PIA 6520. 


CRA-5 

CRA-4 

CRA-3 

CA2 

Gelöscht 

Gesetzt 

1 

1 

0 

Low bei einem negat iven Über¬ 
gang von E nach einer MPU- 
Lase-OP©iation der "A"-Daten 

H rgh. wenn das Unterbrechungs- 
Flag-Bil CRA-7 durch einen 
aktiven Übergang das CA1- 
Signals gesetzt wird. 

1 

1 

■ 

Low bei einem negativen Über¬ 
gang von E nach einer MPU- 
Lese-Operation der 'A 'Dalen 

High bei der negativen Flanke 
des ersten "E"-lmpulses, der 
während der Zeit auftrill, in der 
keine Auswahl vorliegt. 

1 

1 

1 

Low, wenn CRA-3 auf Low gehl, als 
Ergebnis eines MPU-Schreibens 
zum Steuer-Register "AL 

Immer Low, so lange CRA-3 Low 
ist. Wird auf High gehen bei einem 
MPU-Schreiben zum Steuer- 
Register "A'\ das CRA-3 auf 
"Eins" ändert 


1 


tmmer High, so lange CRA-3 High Ist. 
Wird bei einem MPU-Schreiben zum 
Steuer-Register "A" gelöscht, das 
CRA-3 auf "Null" löscht. 

High, wenn CRA-3 auf High als 
Ergebnis eines MPU- 
Schreibens in das Steuer- 
Register "A"geht. 
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Konfigurieren des PIA 


Das Programm muß die Logik-Verbindung im 
PIA auswählen, bevor dieser verwendet wird. 

Diese Auswahl (oder Konfiguration) ist gewöhn¬ 
lich ein Teil der Start-Routine. Die Schritte bei 
der Konfiguration sind: 

1) Adressiere das Datenrichtungs-Register durch Löschen von Bit 2 des Steuer- 
Registers. Da das Reset-Signal alle internen Register löscht, ist dieser Schritt 
in der Gesamt-Startroutine nicht notwendig. 

2) Stelle die Richtungen der E/A-Anschlüsse durch Laden des Datenrichtungs- 
Registers ein. 

3) Wähle die erforderlichen Logik-Verbindungen im PIA durch Laden des 
Steuer-Registers aus. Setze Bit 2 des Steuer-Registers, um das Datenregister 
zu adressieren. 


SCHRITTE BEI DER 
KONFIGURIERUNG 
EINESPIA 


Schritt 1 kann wie folgt ausgeführt werden: 


LDA 

#0 

iLOSCHE PIA-STEUERREGISTER 

STA 

PIACR 


LDA 

PIACR 


AND 

*%11111011 

;WÄHLE DATENRICHTUNGS REGISTER 


Sobald das Programm Schritt 1 ausgeführt hat, ist Schritt 2 einfach eine Angele¬ 
genheit des Löschens jedes Eingangs-Bits und das Setzen jedes Ausgangs-Bits 
im Datenrichtungs-Register. Einige einfache Beispiele sind: 


1) 

LDA 

#0 


STA 

PIADDR 

2) 

LDA 

#$FF 


STA 

PIADDR 

3) 

LDA 

#$F0 


STA 

PIADDR 


;ALLE LEITUNGEN EINGÄNGE 

;ALLE LEITUNGEN AUSGÄNGE 

;SETZE LEITUNGEN 4-7 ALS AUSGÄNGE, 
; 0-3ALS EINGÄNGE 


Schritt 3 ist offensichtlich der schwierige Teil der Konfiguration, da es die Aus¬ 
wahl der Logik-Verbindungen in der PIA beinhaltet. Man muß sich hierbei an ei¬ 
nige Punkte erinnern: 

1) Bit 6 und 7 des Steuer-Registers werden durch Übergänge auf den Steuerlei¬ 
tungen gesetzt und durch Lesen des Datenregisters gelöscht. Man kann die¬ 
se Bits nicht durch Schreiben von Daten in das Steuer-Register ändern. 

2) bit 2 des Stuer-Registers muß gesetzt werden, um das Datenregister zu 
adressieren. 

3) Bit 1 bestimmt, welche Impuls-Flanke Bit 7 setzen wird. Bit 1 ist 0 für einen 
High-auf-Low-Übergang Bit 1 ist 1 für einen Low auf-High-Übergang. 

4) Bit 0 ist die Unterbrechungs-Freigabe für Steuerleitung 1. Erinnern wir uns 
daran, daß es zur Freigabe von Unterbrechungen gesetzt werden muß, im 
Gegensatz zum Unterbrechungs-Bit des 6502, das zur Freigabe von Unter¬ 
brechungen gelöscht werden muß. Kapitel 12 beschreibt Unterbrechungen 
detaillierter. 

5) Bit 5 muß gesetzt werden, wenn Steuerleitung 2 ein Ausgang sein soll. Die 
Bits 3 und 4 bestimmen dann, wie die Steuerleitung 2 arbeitet. Erinnern wir 
uns daran, daß die Seiten A und B differieren, da die Seite A nur einen Lese¬ 
lmpuls erzeugen kann, während die Seite B nur einen Schreib-Impuls bilden 
kann. Sobald die Impuls-Option gewählt wurde, folgen die Impulse automa¬ 
tisch jedem Lesen des Datenregisters A oder Schreiben des Datenregisters 
B. Man muß jede Seite jedes PIA im Startprogramm konfigurieren. 
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BEISPIELE FÜR DIE PIA-KONFIGURATION 


1) Ein einfacher Eingangs-Port ohne Steuerlei¬ 
tungen: 


LDA #0 ;LÖSCHE STEUER REGISTER 

STA PIACR 

STA PIADDR ;MACHE ALLE LEITUNGEN ZU EINGÄNGEN 

LDA #%00000100 ;WÄHLE DATENREGISTER 

STA PIACR 

Bit 2 des Steuer-Registers muß gesetz werden, um das Datenregister zu adres¬ 
sieren. Die gleiche Sequenz kann verwendet werden, wenn eine High-auf-Low- 
Flanke auf der Steuerleitung 1 ein "Daten-Bereit" (Data Ready) oder "Peripherie- 
Bereit" (Peripheral Ready) anzeigt 

2) Ein einfacher Ausgangs-Port ohne Steuerleitungen (wie er für einen Satz ein¬ 
zeln LED-Anzeigen benötigt wird): 

LDA #0 [LÖSCHE STEUER-REGISTER 

STA PIACR 

LDA #$FF [MACHE ALLE LEITUNGEN ZU AUSGÄNGEN 

STA PIADDR 

LFDA #%00000100 ;WÄHLE DATENREGISTER 

STAA PIACR 

3) Ein Eingangs-Port, der DATA READY mit einem Low-auf-High-Übergang (po¬ 
sitiver Übergang anzeigt): 


LDA # 0 [LÖSCHE STEUER-REGISTER 

STA PIACR 

STA PIADDR [MACHE ALLE LEITUNGEN ZU EINGÄNGEN 

LDA #%000001 10 ;MACHE"DATA-READY" AKTIV LOW ZU 
; HIGH 

STA PIACR 

Die Leitungen DATA-READY oder DATA-AVAILABLE werden zu den Steuer¬ 
leitungen CA1 oder CB1 geführt. Bit 1 des Stuerregisters wird so gesetzt, daß 
Low-auf-High-Ubergänge auf der Steuerleitung 1 erkannt werden. Diese Kon¬ 
figuration ist geeignet für die meisten codierten Tastaturen. 

4) Ein Ausgangs-Port, der einen kurzen Impuls zur Anzeige von DATA READY 
und OUTPUT READY erzeugt, (dies könnte zum Multiplexen von Anzeigen 
oder zur Lieferung eines Signales DATA AVAILABLE zu einem Drucker ver¬ 
wendet werden): 


LDA 

#0 

[LÖSCHE STEUER-REGISTER 

CLR 

PIACR 


LDA 

#$FF 

[MACHE ALLE LEITUNGEN ZU AUSGÄNGEN 

STA 

PIADDR 


LDA 

%00101100 

[STEUERLEITUNG 2 = KURZER TASTIMPULS 

STA 

PIACR 
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Bit 5 - 1, um die Steuerleitung 2 zu einem Ausgang zu machen, Bit 4 - 0, um ei¬ 
nen Impuls zu erzeugen, und Bit 3 = 1, um einen kurzen aktiven Low-Impuls 
(eine Taktperiode lang) zu bilden. Der Tast-Impuls wird automatisch jedem Be¬ 
fehl folgen, der Daten in die B-Seite des PIA schreibt. Zum Beispiel wir der Be¬ 
fehl 

STA PIADRB 

sowohl Daten transferieren, als auch einen Tast-Impuls bewirken. Die A-Seite 
ledoch wird einen Tast-Impuls nur nach einer Lese-Operation erzeugen. Die Se¬ 
quenz 

STA PIADRA ;SCHREIBE DATEN 

LDA PIDR ;ERZEUGE EINEN AUSGANGS-TAST-IMPULS 

wird sowohl Daten tranfeneren als auch einen Tast-Impuls bewirken. Der LDA- 
Befehl ist ein "Leer-Lesen" (dummy read). Er hat keinen anderen Einfluß, als 
den Tast-Impuls zu bewirken (und einige Zeit zu verwenden). Andere Befehle 
neben LDA könnten ebenfalls verwendet werden (zählen Sie einige auf). 

5) Ein Eingangs-Port mit einem Bestätigungs-Impuls für einen Quittierungs- 
Eingang der dazu verwendet werden kann, um einem peripheren Gerät mit¬ 
zuteilen, daß die vorausgehenden Daten angenommen wurden (und der 
Computer bereit für weitere ist): 

LDA #0 [LÖSCHE STEUER REGISTER 

STA PIACR 

STA PIADDR [MACHE ALLE LEITUNGEN ZU EINGÄNGEN 

LDA #%00100100 [STEUERLEITUNG 2-OUITTIERUNGS- 

; BESTÄTIGUNG 

STA PIACR 

Bit 5 - 1, um die Steuerleitung 2 zu einem Ausgang zu machen, Bit 4 - 0 für 
einen Impuls, und Bit 3 = 0, um eine Quittierung mit aktiv Low zu bilden, die 
Low bis zum nächsten aktiven Übergang auf der Steuerleitung 1 bleibt. Der 
Bestätigung wird automatisch eine Lese Operation auf der A-Seite des PIA 
folgen. Zum Beispiel wird der Befehl 

LDA PIADRA 

sowohl die Daten lesen, wie auch die Bestätigung bewirken. Die B-Seite wird 
ledoch eine Bestätigung nur nach einer Schreib-Operalion erzeugen. Die 
Sequenz 

LDA PIADRB [LIES DATEN 

STA PIADRB [ERZEUGE BESTÄTIGUNG 

wird sowohl die Daten lesen, als auch eine Bestätigung erzeugen Der STA- 
Befehl ist ein "dummy-write". Er hat keinen anderen Effekt, als die Bestäti¬ 
gung zu erzeugen (und einige Zeit zu verwenden). Beachten Sie, daß die 
Reihenfolge der Sequenz gegenüber dem vorhergehenden Beispiel umge¬ 
kehrt wurde. Diese Konfiguration ist geeignet für zahlreiche Bildschirm- 
Terminals. die eine vollständige Quittierung benötigen. 
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6) Ein Ausgangsport mit einem zwischengespeicherten Null-Steuer-Bit (zwi¬ 
schengespeicherter individueller Ausgang oder Pegel Ausgang). Ein derarti¬ 
ger Ausgang kann zum Ein oder Ausschalten des peripheren Gerätes ver¬ 
wendet werden, oder zur Stuerung seiner Betriebsart. 

LDA #0 ;LÖSCHE STEUER-REGISTER 

STA PIACR 

LDA # $FF ;MACHE ALLE LEITUNGEN ZU AUSGÄNGEN 

STA PIADDR 

LDA #%00110100 ;STEUERLEITUNG 2 GESPEICHERTER 
; NULL-PEGEL 

STA PIACR 

Bit 5 - 1, um die Steuerleitung 2 zu einem Ausgang zu machen Bit 4 - 1, um 
einen Pegel oder ein gespeichertes Bit zu bilden, und Bit 3 - 0, um den Pegel 
null zu machen. Dieses Bit wird nicht durch die Operationen am Datenregi¬ 
ster beeintlußt. Sein Wert kann durch Ändern des Wertes von Bit 3 verändert 
werden, das heißt: 

LDA PIACR 

ORA #%00001000 ;MACHE PEGEL EINS 
STA PIACR 

LDA PIACR 

AND 4L %11110111 .MACHE PEGEL NULL 

STA PIACR 

Man kann diese Konfiguration verwenden, um Tast-Impulse mit aktiv High zu 
erzeugen oder Impulse zu liefern, bei denen die Länge durch die Software 
gesteuert wird. 
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VERWENDUNG DES PIA ZUM TRANSFERIEREN VON DATEN 


Sobald der PIA konfiguriert wurde, kann man seine Da- PIA-EINGABE/ 
tenregister wie jeden anderen Speicherplatz verwenden. AUSGABE 
Die einfachsten Befehle für den Datentransfer sind: - 

"Lade Akkumulator" transferiert 8 Datenbits von dem spezifizierten Eingangs- 
Anschlüssen zum Akkumulator. 

"Speichere Akkumulator" transferiert 8 Datenbits von einem Akkumulator zu 
den spezifizieten Ausgangs-Anschlüssen. 

Man muß sehr sorgfältig in Situalione Vorgehen, bei denen Eingangs- und Aus¬ 
gangs-Ports sich nicht wie Speicherplätze verhalten. Beispielsweise hat es häu¬ 
fig keinen Sinn, Daten in Eingangs-Ports zu schreiben oder Daten von Aus¬ 
gangs-Ports zu lesen. Besonders sorgfältig muß man vorgehen, wenn der Ein¬ 
gangs-Port nicht zwischengespeichert ist oder wenn der Ausgangs Port nicht 
gepuffert ist. 

Andere Befehle, die Daten zu oder vom Speicher transferieren, können auch 
als E/A-Befehle dienen. Typische Beispiele sind: 

Bit-Test, der das Nullltag setzt, als ob die Werte eines Satzes von Eingangs- 
Pins logisch mit dem Inhalt des Akkumulators UNDiert worden wären. Das Vor¬ 
zeichen- (Negativ)Flag wird auf den Wert von Bit 7 des Eingangsports und das 
Überlauf-Flag wird auf den Wert von Bit 6 des Eingangsports gesetzt. Dieser Be¬ 
fehl liefert einen einfachen Weg, um die PIA-Statusflags zu testen. Das heißt, 
der Befehl 

BIT PIACR 

setzt das Vorzeichen-Flag auf den Wert des Steuerregister-Bits 7 (der Status- 
Zwischenspeicher für Steuerleitung 1) und das Überlauf-Flag auf den Wert des 
Steuerregister-Bit 6 (der Status-Zwischenspeicher für Steuerleitung 2). 

"Compare” setzt die Flags, als ob sie Werte eines Satzes von Eingangs-An¬ 
schlüssen wären, die vom Inhalt des Akkumulators subtrahiert wurden. 

Hier muß man sich auch die physikalischen Grenzen der E/A-Ports vor Augen 
halten. Besonders sorgfältig muß man bei Befehlen für Verschieben, Komple¬ 
mentieren, Inkrementieren und Dekrementieren sein, die sowohl Lese- wie 
Schreibzyklen beinhalten. 

Man kann die Bedeutung einer sorgfältigen Dokumentation nicht nachdrück¬ 
lich genug betonen. Häufig können komplexe E/A-Transfers in Befehlen ver¬ 
steckt sein, die keine offensichtlichen Funktionen besitzen. Man muß den Zweck 
derartiger Befehle sehr sorgfältig beschreiben. Beispielsweise könnte jemand 
versucht sein, die "dummy read"- und "write"-Operationen, die früher erwähnt 
wurden, zu entfernen, da sie scheinbar keine Funktion besitzen. 
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Bit 7 des PIA-Steuer'Registers dient häufig als Status-Bit, 

wie etwa "Data Ready" oder "Peripheral Ready". Man kann 
ihre Werte mit einer der folgenden Sequenzen überprüfen: 


LDA 

PIACR 

;IST READY-FLAG 1 ? 

BMI 

DEVRDY 

;JA, BAUSTEIN BEREIT 

BIT 

PIACR 

;IST READY FLAG 1? 

BMI 

DEVRDY 

;JA, BAUSTEIN BEREIT 


Beachten Sie. daß man Schiebe-Befehle nicht verwenden sollte, da Sie den In¬ 
halt des Steuer-Registers verändern werden (warum?). Das folgende Programm 
wird darauf warten, daß das Ready-Flag auf High geht: 

WAHR BIT P1ACR ;IST READY-FLAG 1? 

BPL WAITR ;NEIN, WARTE 

Wie würden Sie diese Programme ändern, so daß Sie Bit 6 anstatt Bit 7 prüfen? 

Der einzige Weg zum Löschen von Bit 7 (oder Bit 6) ist das Lesen des Datenre¬ 
gisters. Ein "dummy read" wird erforderlich sein, wenn eine Lese-Operation nor¬ 
malerweise nicht Teil der Reaktion auf das gesetzte Bit ist. Wenn der Port für 
Ausgabe verwendet wird, so wird die Sequenz 

STA PIADR ;SENDE DATEN 

LDA PIADR 1ÖSCHE LESE-FLAG 

diese Aufgabe erfüllen. Beachten Sie, daß hier das "dummy read" auf jeder Sei¬ 
te des PIA erforderlich ist. Der Testbefehl kann auch den Tast-Impuls ohne ir¬ 
gendwelche anderen Änderungen löschen, mit Ausnahme der Flags. Seien Sie 
besonders sorgfältig in Fällen, bei denen die CPU nicht bereit für die Eingabe 
von Daten ist, oder Keine Ausgangsdaten zu senden hat. 
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DER VERSATILE INTERFACE-ADAPTER (VIA) 6522 


Der "Vielseitige Interface-Adapter” 6522 ist eine verbesserte Version des peri¬ 
pheren Inteiface-Adapters 6520. 6 ' 7 ' 8 

Der VIA 6522 enthält folgendes (siehe Blockschaltbild in 

Bild 11-8): 

1) Zwei 8-Bit-E/A-Porte (A und B). Jeder Anschluß kann individuell ausge¬ 
wählt werden, um entweder als Eingang oder als Ausgang zu dienen. 

2) Vier Status- und Steuerleitungen (zwei jedem Port zugeordnet). 

3) Zwei 16-Bit-Zähler/Zeitgeber, die zur Erzeugung oder zum Zählen von Im¬ 
pulsen verwendet werden können. Diese Zeitgeber können einzelne Impulse 
oder eine kontinuierliche Serie von Impulsen erzeugen. 

4) Ein 8-Bit-Schieberegister, das Daten seriell/parallel umwandeln kann. 

5) Unterbrechungslogik (wird in Kapitel 1 2 beschrieben), so daß E/A auf einer 
unterbrechungsgesteuerten Basis ausgeführt werden kann. 

Der vielseitige Interface Adapter liefert die Funktionen des PIA, plus zweier 
16-Bit-Zähler/Zeitgeber und einem 8-Bit-Schieberegister. Wir wollen die Ver¬ 
wendung der Zähler/Zeitgeber später in diesem Kapitel behandeln Das Schie¬ 
beregister liefert eine einfache serielle E/A-Möglichkeit, die nur gelegentlich von 
Nutzen ist. Wir wollen sie daher nicht weiter besprechen. 
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Jeder VIA belegt 16 Speicher-Adressen. Oie RS-Leitungen 
(Register Select) wählen die verschiedenen internen Regi¬ 
ster aus, wie in Tabelle 11-7 beschrieben ist. Die Art 

und Weise, in der ein VIA arbeitet, wird durch den Inhalt von vier Registern be¬ 
stimmt. 

1) Datenrichtungs-Register A (DDRA= Data Directlon Register A) bestimmt, ob 
die Anschlüsse an Port A Eingänge oder Ausgänge sind. 

2) Datenrichtungs-Register B (DDRB) bestimmt, 
ob die Anschlüsse an Port B Eingänge oder 
Ausgänge sind. 

3) Das periphere Steuerregister (PCR = Peripheral Control Register) bestimmt, 
welche Polarität des Übergangs (Anstiegsflanke oder abfallende Flanke) auf 
den Eingangs-Statusleitungen (CA1 und CB1) erkannt wird, und wie die 
anderen Stalusleitungen (CA2 und CB2) arbeiten. Bild 11-9 beschreibt die 
Bä-Zuweisungen im peripheren Steuerregister. Wie gewöhnlich sind die 
Funktionen und Bit-Positionen willkürlich vom Hersteller ausgewählt wor¬ 
den. Beachten Sie, daß das periphere Steuerregister des 6522 nicht Status- 
Bits (zwischengespeichert) enthält, wie die Steuerregister des 6520. Diese 
Bits liegen im seperaten Unterbrechungsflag-Register (siehe Bild 11-11). 

4) Das Hilfssteuer-Register (ACR = Auxiliary Control Register) bestimmt, ob 
die Datenports zwischengespeichert werden und wie die Zeitgeber und das 
Schieberegister erarbeiten. Diese Funktionen sind im PIA 6520 nicht enthal¬ 
ten. Bild 11-10 beschreibt die Bit-Zuweisungen im Hills-Steuerregister. 

Beachten sie, daß es ein Datenrichtungs Register für jede Seite gibt, jedoch nur 
ein Steuerregister (anders als beim 6520, der ein seperates Steuerregister für 
jede Seite besitzt). Die Ports A und B sind im wesentlichen identisch. Ein wichti¬ 
ger Unterschied besteht darin, daß Port B Dariington-Transistoren ansteuern 
kann, die zum Treiben von Spulen und Relais verwendet werden. Wir wollen Port 
A für Eingabe und Por: B für Ausgabe in unseren Beispielen später in diesem 
Kapitel verwenden. 
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Bild 11-8 Blockschaltbild des Vielseitigen Interface-Adapters 6522. 



















Tabelle 11-7. Adressierung der internen Register des VIA 6522. 


- r 

Auswahl- 

Leitungen 


Adressierter Speicherplatz 

Label 

RS3 

RS2 

a 

3 

DEV 

0 

0 

0 

0 

Ausgangs-Register fürE/A-Port B 

DEV*1 

0 

0 

0 

1 

Ausgangs-Regislertür E/A-Pori A mit duittierung 

DEV+ 

0 

0 

1 

0 

Dalenrichlungs-Regisler des E/A-Ports B 

DEV+3 

0 

0 

1 

1 

Dalenrlchlungs-Register des E/A-Porls A 

DEV+4 

0 

1 

0 

0 

Lies niederwertiges Byte des Zählers von Zeitgeber 1 

Schreibe zum niederwertigen Byte des Zwischenspeichers von 
Zeitgeber 1 

DEV+5 

0 

1 

0 

1 

Lias hochwertiges Byte das Zählers von Zeitgeber l 

Schreibe zum hochwertigen Byte des Zwischenspeichers von 
Zeitgeber 1 und initiiere Zählung 

DEVr6 

0 

1 

1 

0 

Graile auf anderweitiges Byte des Zwischenspeichers von 

Zeitgeber 1 zu 

DEV.7 

0 

1 

1 

1 

Greile aut hochwertiges Byte des Zwischenspeichers von 

Zeitgeber 1 zu 

DEV+8 

1 

0 

0 

0 

Lies niederwertiges Byte von Zeitgeber 2 und lösche 
Zahler-Unterbrechung 

Schreibe zu niederwertigem Byte von Zeitgeber 2. lösche 
jedoch Unterbrechung nicht 

DEV+9 

1 

0 

0 

1 

Greile aul hochwertiges Byte von Zeitgeber 2 zu. lösche 
Zähler-Unterbrechung beim Schreiben 

DEV+A 

1 

0 

1 

0 

Serielles E/A Schiebe-Register 

DEV+B 

1 

0 

1 

1 

Hills-Stauar-Register 

DEV+C 

1 

1 

0 

0 

Peripheres Steuer-Register 

DEV+D 

1 

1 

0 

1 

Unterbrechungs-Fiag-Register 

DEV+E 

1 

1 

1 

0 

Unterbrechungs-Freigabe-Regisler 

DEV+F 

1 

1 

1 

11 

Ausgangs-Register lür E/A-Pori A. ohne Quittierung 


7 6 5 4 3 2 1 o 


CT 


CP 




-Bit-Numcne» 

-Peripheres Steuer-Regster 


Forciere Unterbrechung bei High- i 
auf-Low-Übergang von C AI an \ 
1 Unterbrechung bei Low- / 

aur-H^-Ubsr^ngwon CAt an I 


Fordere Unterbrechung bei 
Low-auf-High-LAjärgang von 
CA2an 


|_000 CA2-Eirtgengs Betriebsart 

001 CA2 unabhängige Betnebsait 


Fottee Unterbrechung bei 
H»gh-aut-Cow-Übergang von 
CA2an 


010 CA2-Eingangs Betriebsart » Fordere Unterbrechung bei 
011 CA2 unabhängige Eingangs- > Low-auf-High-Übergang von 
Betriebsart J CA2 an 

tOO CA2-Ausgang Low bei CPU Lesen oder Schreiben 
101 CA2-Ausgang '^rw-ffTDuis bei CPO-Lesen oder Schreiben 

HO Ausgang CA2 Low 

111 Ausgang CA2 High 


( Bei Unter- 
Wbchung#- 
Anforderung 
setze Unter- 
brechungs- 
Flag-Regi- 
stesbrtO 


*0 Fordere Unterbrechung ber High- 
auM-Ow-Ubergang von CBl an 
1 Fordere Unterbrechung bei Low- 
auf-High-Übergang von CBl an 

.000 C82-Eingangs-Bethebsail 
001 C82 unabhängige Bdlneb&ait 

010 CB2-€rnga^ »-Betriebsart 
011 CB2 unabhängige Eingangs- 
Betriebsart 

100 CB2-Ausgang Lew bei CPU¬ 
Lesen oder Schreiben 
1 ■ 1 CB2-Ausgang Low-Impuls bei 
CPU-Lesen oder Sehr eiben 

110 Ausgang CB2 Low 

111 Ausgang CB2 High 


Bei U rrtwbrechunga-Anfor- 
derung setze Unlarbre- 
chungs-Flag-Registerbil 4 


i Fordere Unterbrechung bei 
f High-aut-Low-Ubergang von 
' CB2 an 

| Fordere Unterbrechung bei 
> Low-auf-High-Übergang von 
1 CB2 an 


! 0e i Unter- 
brechungs- 

Anfotdryvjng 
setae Unter- 
txechungs- 
Flac-Regi¬ 
sterbit 3 


Bild 11 -9. Bit-Zuweisungen tür das periphere Steuer-Register des VIA 6522 


Bit-Nummer 

Hilts-Steuer-Regisler 


0 Sperre Eingangs-Zwischenspeicher'an Port A 
1 GibBngaitgs-ZwiSchOT&mcteran Port A fr» 

0 Spore Eingang8-Z»»schen^jfcf*che< an Port B 
1 Gb Emgangs-Zwischansoeicher an Port B Irei 

000 Sperre Schiebe-Register 
001 Schiebe mH: Rate des Zählers 2 ein 
010 Schiebe mit 4» 2-Taktiate ein 
011 Schiebe mit externer Taktrate ein 

100 Freäauf^Kfer AusOang mit Taktrate von Zähler 2 

101 Sch«*>e mit Tektrate von Zähler 2 aus 

110 Schiebe mit <t> 2-Takirate aus 

111 Schiebe mit externer Taktrate aus 


0 Dekrementiere Zählerbei2-Tekt, in monostabiler 
Beliiebsan 

1 Dekrementiere Zähler 2 bei externen Impuls-Eingängen 
überPBS 

■ OSpeiie Ausgabe über PB7 1 
1 G4> Ausgebe (ibefPQ 7 frei I SIBuenJn g«x, 

0 K*T*EiMik) Betriebsart I Zähl» i 

1 Freitaulende aetr-Asart I 



Bild 11-1 0. Bit Zuweisungen für das Hilfs-Steuer Register des VIA 6522 
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KONFIGURIEREN DES VIA 


SCHRITTE BEI DER 

Das Programm muß die logischen Verbindungen KONFIGURIERUNG 

im VIA auswählen, bevor dieser verwendet wird. EINES VIA 

Diese Auswahl (oder Konfiguration) ist gewöhn--——- 

lieh Teil der Start-Routine. Die Schritte dienen zum Einnchten der Richtungen 
der E/A-Anschlüsse durch Laden des Datenrichtungs-Registers und zur Aus¬ 
wahl der erforderlichen Logik-Verbindungen im VIA durch Laden des penpheren 
Steuerregisters und falls erfrderlich, des Hilfs-Steuerregisters. 


Sie können die Richtungen derE/A-Anschiüsse wie folgt einstellen: 


1) Eine "0" in einem Bit im Datenrichtungsregi¬ 
ster macht den entsprechenden Anschluß zu 
einem Eingang. Zum Beispiel macht eine "0" 
in Bit 5 des Datenrichtungs-Registers A den 
Anschluß PA5zu einem Eingang. 


EINRICHTEN DER 

VIA-PIN- 

RICHTUNGEN 


2) Eine "1" in einem Bit im Datenrichtungs-Register macht das das entspre¬ 
chende Pin zu einem Ausgang. Zum Beispiel macht eine 1 im Bit 3 des Da- 
tenriehtungs-Registers B den Anschluß PB3 zu einem Ausgang. 


Die Richtungen der meisten E/A-Anschlüsse sind nach der Initialisierung festge¬ 
legt, da die meisten Eingangs-und Ausgangsleitungen Daten nur in einer Rich¬ 
tung transferieren (d h., der Mikroprozessor wird niemals Daten von einem 
Drucker holen oder Daten zu einer Tastatur senden). 


Einige einfache Beispiele zum Einstellen der Richtungen sind: 


LDA 

#0 

;ALLE LEITUNGEN EINGÄNGE 

STA 

VIADDRA 


LDA 

#$FF 

ALLE LEITUNGEN AUSGÄNGE 

STA 

VIADDRB 


LDA 

#$F0 

.MACHE LEITUNGEN 4-7 ZU AUSGÄNGEN, 
; 0-3 ZU EINGÄNGEN 

STA 

VIADDRB 



Sie können Eingänge und Ausgänge an einem einzelnen Port mischen, indem 
Sie die Richtungen der individuellen Anschlüsse entsprechend einnchten. Port B 
ist gepuffert, so daß sein Inhalt korrekt gelesen werden kann, auch wenn er als 
Ausgang verwendet wird. Port A ist nicht gepuffert, so daß sein Inhalt nur dann 
korrekt gelesen werden kann, wenn er nicht zu sehr belastet wird 
(oder als Eingänge dient). 

Das Konfigurieren des VIA Ist infolge seiner PERIPHERES 

zahlreichen Funktionen etwas schwierig. Die STEUERREGISTER 

meisten E/A-Poit-Funktlonen werden vom P«ri- DES VIA _ 

pheren Steuerregister kontrolliert und wir wer- 

den daher diese zuerst behandeln. Man merke sich daher folgendde Punkte. 

1) Reset löscht alle VIA-Register, macht alle Leitungen zu Eingängen und 
sperrt alle Unterbrechungen Alle Flanken-Detektoren sind so eingestellt, daß 
sie an der abfallenden Flanke (High-auf-Low-Übergänge) tnggern. 
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2) Die Bits 0-3 des peripheren Steuerregisters werden zum Einrichten der lo¬ 
gischen Verbindung für die Skeuerleitungen CA1 und CA2 verwendet. Die 
Bits 4-7 haben den gleichen Zweck für die Stuerieitungen CB1 und CB2. 

3) Die Steuerleitungen CA 1 und CB1 sind immer Eingänge. Die einzige Wahl¬ 
möglichkeit besteht darin, ob die entsprechenden Status-Zwischenspeicher 
(Unterbrechungsflag-Registerbits 1 und 4 - siehe Bild 11-11) auf abfallende 
Flanken (High-auf-Low-oder Negativ-Übergänge) oder auf ansteigende 
Flanken (Low-auf-High. oder positive Übergänge) eingestellt sind. Für CA1, 
Bit 0-0 für abfallende Flanken und 1 für ansteigende Flanken. Für CB1, Bit 4 
- 0 für abfallende Flanken und 1 für ansteigende Flanken. 

4) Die Steuerleitungen CA2 und CB2 können entweder Eingänge oder Aus¬ 
gänge sein (siehe T abeile 11 -8 und 11 -9). Für CA2, Bit 3 - 1 macht sie zu ei¬ 
nem Ausgang und 0 zu einem Eingang. 


Tabelle 11-8. Konfigurationen der Steuer-Leitung CA2 des VIA 6522. 


PCR7 PCR6 PCR5 


Betriebsait 

Unterbrechungs-Eingangs-Betriebsart - Setze CB2- 
Unterbrechungs-Flag (IFR3) bei einem negativen 
Übergang des CB2-Eingangs Signals. Lösche IFR3 
beim Lesen oder Schreiben des peripheren 
B Ausgangs Registers. 

Unabhängige Unterbrechungs-Eingangs-Betriebs- 
art - Setze IFR3 bei einem negativen Übergang des 
CB2-Eingangs-Signals. Lesen oder Schreiben von 
ORB löscht das Unterbrechungs-Flag nicht 

Eingangs-Betriebsart - Setze CB2-Unterbrechungs- 
Flag bei einem positiven Übergang des CB2- 
Eingangs-Signals. Lösche das CB2-Unterbre- 
chungs-Flag bei einem Lesen oder Schreiben von 
ORB. 

Unabhängige Eingangs-Betriebsart - Setze IFR3 bei 
einem positiven Übergang des CB2-Eingangs- 
Signals. Lesen oder Schreiben von ORB löscht das 
CB2-Unterbrechungs-Flag nicht. 

Ouittierungs-Ausgangs-Betnebsart - Setze CB2 auf 
Low bei einer ORB-Schreib-Operation. Setze CB2 
auf High zurück mit einem aktiven Übergang des 
CB1 -Eingangs-Signals. 

Impuls-Ausgangs-Betriebsait - Setze CB2 auf 
Low für die Dauer eines Zyklus nach einer ORB- 
Schreib-Operation. 

Manuelle Ausgangs-Betriebsart-Der CB2-Ausgang 
wird in dieser Betriebsart auf Low gehalten. 

Manuelle Ausgangs-Betriebsart - Der CB2-Ausgang 
wird in dieser Betriebsart auf High gehalten 
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Tabelle 11 -9. Konfigurationen der Steuer-Leitung CB2 des VIA 6522. 


PCR3 

PCR2 

PCR1 

Betriebsart 

0 

0 

0 

Eingangs-Betriebsart - Setze CA2-Unterbrechungs- 
Fiaq (IFRO) bei einem negativen Übergang des 
Eingangs-Signals, lösche IFRO bei einem Lesen 
oder Schreiben des peripheren A-Ausgangs-Regi- 
sters. 




Unabhängige Unterbrechungs-Eingangs-Betriebsart 

- Setze IFRO bei einem negativen Übergang des 
CA2-Eingangs-Signals. Lesen oder Schreiben von 
ORA löscht das CA 2 -Unterbrechungs-Flag nicht. 

1 


0 

Eingangs-Betriebsart - Setze CA2-Unterbrechungs- 
Flaq bei einem positiven Übergang des CA2- 
Eingangs-Signals. lösche IFRO mit einem Lesen 
oder Schreiben des peripheren A-Ausgangs-Regi- 
sters. 


1 

■ 

Unabhängige Unterbrechungs-E,ngangs-Betriebsart 

- Setze IFRO bei einem positiven Übergang des 
CA2-Eingangs-Signals. Lesen oder Schreiben von 
ORA löscht das CA 2 -Unterbrechungs-Flag nicht 

1 

0 

■ 

Quittierungs-Ausgangs-Betriebsart - Setze CA2- 
Ausgang auf Low bei einem Lesen oder Schreiben 
des peripheren A-Ausgangs-Registers. Lösche CA2 
auf High mit einem aktiven Übergang an CA1. 

■ 

0 

■ 

Impuls-Ausgangs-Betriebsart - CA2 geht auf Low 
für die Dauer eines Zyklus nach einem Lesen oder 
Schreiben des peripheren A Ausgangs-Registers. 

■ 

1 

B 

Manuelle Ausgangs-Betriebsart - Der CA2-Ausgang 
wird in dieser Betriebsart auf Low gehalten. 

1 

1 

1 

Manuelle Ausgangs-Betriebsart - Der CA2-Ausgang 
wird in dieser Betriebsart auf High gehalten 


76543210 ^ Bit-Nummer 


I- 






■■ 

■1B 


Ll 

TI 

T2 

CB1 

CB2 

SR 

CA1 

_ 

^ Register 


Bit-Nr 

Gesetzt durch 

Gelöscht durch 

■ 

Aktiver Übergang des Signals 
am Pin CA2 

Lesen oder Schreiben des A-Port- 
Ausgangs-Registers (ORA) unter Ver¬ 
wendung der Adresse 0001 


Aktiver Übergang des Signals 
am Pin CA1 

Lesen oder Schreiben des A-Pocl- 
Ausgangs-Regisiers (ORA) unter Ver¬ 
wendung der Adresse 0001 


Ausführung von acht 

Verschiebungen 

Lesen oder Schreiben des Schiebe- 
Registers 

3 

Aktiver Übergang des Signals 
am Pm CB2 

Lesen oder Schreiben des B-Porl- 
Ausgangs-Registers 

4 

Aktiver Ub rgeng des Signals 
am Pin CB1 

Lesen oder Schreiben des B-Port* 
Ausgangs-Registers 

5 

Ablauf von Zeitgeber 2. 

Lesen des niederwenigen Zählers von 

T 2 oder Schreiben des hochwertigen 
hlers von TI. 

6 

Ablaut von Zeitgeber 1, 

Lesen des niederwertigen Zählers von 

TI oder Schreiben des hochwertigen 
Zwischenspeichers von Ti 

■ 

Aktive und freigegebene 
Unterbrechungs-Bedingung 

Tätigkeit, die die Unterbrechungs¬ 
bedingung löscht 

Die Bits 0, 1, 3 und 4 sind die E/A-Guiltierungs-Signale. Bil 7 (IRQ) ist t. wenn eine der 
Unlerbre hungen sowohl aktiv wie Ireigegeben ist (siehe Kapitel t2)_ 


Bild 11-11. Das 6522-VIA-Unterbrechungs-Flag-Register. 
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Weitere Funktionen sind fol gende: 

CA2-Eingang 

Bit 2= 1, um an einer ansteigenden Flanke zu triggern, 0, um an einer abfallen¬ 
den Flanke zu triggern. 

Bit 1 = 1, um das Unterbrechungsflag-Registerbit 0 (der CA2-Eingangsstatus- 
Zwischenspeicher) unabhängig von Operationen am E/A-Port A zu machen. 0 
um dieses Bit durch Operationen am E/A-Porl A zu löschen. 

Die unabhängige Betriebsart ist sehr nützlich, wenn CA2 für Zwecke verwendet 
wird, (wie einer Echlzeit-Uhr), die vollständig unabhängig von Datentransfers 
über den E/A-Poit sind. Die reguläre Betriebsart ist nützlich, wenn CA2 als ein 
Ouiltierungssignal verwendet wird, das gelöscht werden muß, um die nächste 
E/A-Operation vorzubereiten (siehe Bilder 11-5 und 11 -6). 


CA2-Ausgang 

Bit 2 = 1 um CA2 zu einem Pegel zu machen, 0 um es zu einem Impuls zu 
machen. 

Wenn CA2 ein Pegel ist, ist Bit 1 dessen Wert, 

Wenn CA2 ein Impuls ist, Bit 1 gleich 0, um CA2 auf Low zu bringen, wenn die 
CPU Daten zu oder vom Port A transferiert und verbleibt Low, bis ein aktiver 
Übergang an CA1 auflritt. Bit 1 - 1 um CA2 Low für einen Taktzyklus, nachdem 
die CPU Daten zu oder vom Port A transferiert hat, zu bringen. 

CB2 wird genauso gehandhabt (Verwendung der Bits 7,6 und 5 des peripheren 
Steuerregisters und Bit 3 des Unterbrechungsflag-Registers} mit Ausnahme, daß 
Impulse an CB2 nur erzeugt werden, nachdem die Daten in den Port B geschrie¬ 
ben wurden. Um einen Impuls nach dem Lesen von Daten zu erzeugen, müssen 
Sie ein "dummy write" verwenden, das heißt: 

LDA VIAORB ;HOLE DATEN VON PORT B 

STA VIAORB ;ERZEUGE TAST-IMPULS VON PORT B 


Die einzige E/A-Port-Funktion, die vom Hilfs- 
Steuerregister abhängig ist (Bild 11-10) isl das 
Zwischenspeichern des Eingangssignals Bit 0 
(für Port A) oder Bit 1 (für Porl B) muß geselzt 
werden um die Eingangsdaten bei einem aktiven Übergang auf der Steuerlei- 
lung 1 zwischenzuspeichern (wie durch das periphere Steuerregister 
bestimmt wird). Beachten Sie die folgenden Eigenschaften der Zwischen¬ 
speich er-Funktlon: 

1} RESET sperrt die Eingangs-Zwischenspeicher Der VIA 6522 arbeitet dann 
wie der PIA 6520, der keine Emgangs-Zwischenspeicherung besitzt. 

2) Für Port A werden die zwischengespeicherten Daten immer die Daten an 
den penpheren Anschlüssen sein. Da Port A nicht gepuffert ist, können die¬ 
se Daten nicht dieselben sein wie die Daten im Ausgangsregister, wenn der 
Port für Ausgabe verwendet wird. 

3) Für Poil B sind die zwischengespeicherten Daten entweder die Daten an den 
peripheren Anschlüssen (lür jene Pins, die als Eingänge definiert sind) oder 
der Inhalt der Ausgangsregisler (für jene Pins, die als Ausgange delmieit 
sind). 

Einige einfache Beispiele für die Aktivierung der Eingangs-Zwischenspeicher 
sind: 


LDA 

#%00000001 


STA 

VIAACR 

iAKTIVIERE ZWISCHENSPEICHER AN 
: PORTA 

LDA 

#%00000010 


STA 

VIAACR 

;AKTIVIERE ZWISCHENSPEICHER AN 
; PORT B 

LDA 

*%00000011 


STA 

VIAACR 

iAKTIVIERE ZWISCHENSPEICHER AN DEN 
; PORTSA UND B 


Beachten Sie, daß die Ausgangsporis des 6522 automatisch zwischenge¬ 
speichert werden, so wie die Ausgangspoits des 6520. 


EINGANGS¬ 

ZWISCHENSPEICHER 

DESVIA 
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1) Ein einfacher Eingangsport ohne Steuerlei» 
tungen (wie für einen Satz von Schaltern 
benötigt wird): 


LDA 

#0 


STA 

VIAPCR 

;MACHE ALLE STEUERLEITUNGEN ZU EIN 
. GÄNGEN 

STA 

VIADDRA 

:MACHE PORT-A-LEITUNGEN ZU EIN- 


: GÄNGEN 

Erinnern Sie sich daran, daß Reset alle internen Register löscht, so daß diese 
Sequenz nicht unbedingt erforderlich ist, Die gleiche Sequenz kann verwendet 
werden, wenn eine High-auf-Low-Fianke (abfallende Flanke) auf der Steuerlei¬ 
tung CA1 ein Data Ready oder Peripheral Ready anzeigt. 

2) Ein einfacher Ausgangsport ohne Steuerleitungen (wie für einen Satz einzel¬ 
ner LED-Anzeigen benötigt wird): 


LDA 

#0 


STA 

VIAPCR 

;MACHE ALLE STEUERLEITUNGEN ZU EIN- 
; GÄNGEN 

LDA 

#SFF 


STA 

VIADDRB 

:MACHE PORT-B-LEITUNGEN ZU AUS- 
: GÄNGEN 


3) Ein Eingangsport ohne aktives Low-auf-High-Signal DATA READY, das CA1 
zugeführt wird (wie für eine nicht codierte Tastatur erforderlich ist): 


LDA 

#0 


STA 

VIADDRA 

.MACHE PORT-A LEITUNGEN ZU EIN- 
, GÄNGEN 

LDA 

#1 

;MACHE ANSTEIGENDE FLANKE AKTIV 

STA 

VIAPCR 



Bit 1 des peripheren Steuerregisters wird gesetzt, um Low-auf-High-Ubergange 
auf der Steuerleitung CA1 zu erkennen. Ein derartiger Übergang wird Bit 1 des 
Unterbrechungsflag-Registers (siehe Bild 11-10) setzen. Das Lesen von Daten 
vom Port wird dieses Bit löschen (siehe Tabelle bei Bild 11-11). Das 
Eingangs-Zwischenspeichern kann erfolgen, indem Bit 0 des Hilfs-Steuerregi¬ 
sters gesetzt wird 

4) Ein Ausgangsport, der einen kurzen Impuls erzeugt, um DATA READY oder 
OUTPUT READY anzuzeigen (dies könnte für das Multiplexen von Anzeigen 
oder für das Liefern eines Signales DATA AVAILABLE zu einem Drucker er¬ 
forderlich sein): 

LDA #$FF 

STA VIADDRB ;MACHE PORT-B-LEITUNGEN ZU AUS- 
, GÄNGEN 

LDA *%10100000 
STA VIAPCR 


5) Ein Eingangsport mit einem Quittierungs-Impuls Input Acknowledge (Ein¬ 
gangs-Bestätigung), der verwendet werden kann, um einen peripheren 
Baustein mitzuteilen, daß die vorhergehenden Daten angenommen wurden 

(und das der Computer bereit für weitere ist): 

LDA #0 

STA VIADDRA ;MACHE PORT-A-LEITUNGEN ZU EIN- 
; GÄNGEN 

LDA #%00001000 .STEUERLEITUNG 2-OUITTIERUNGSBE- 
; STÄTIGUNG 

Der Impuls auf der Steuerleitung CA2 wird nach jeder Eingabe-oder Ausgabe 
Operation auftreten. Er wird bis zum nächsten aktiven Übergang auf der Steuer¬ 
leitung CA1 auf Low bleiben. Bit 3 des peripheren Steuerregisters ist 1, um CA2 
zu einem Ausgang zu machen, Bit 2 ist 0, um CA2 zu einem Impuls zu machen, 
und Bit 1 ist 0. um CA2 zu einem Bestätigungssignal mit aktiv Low zu machen, 
das bis zum nächsten aktiven Übergang an CA1 dauert. Beachten Sie. daß der 
aktive Übergang an CA1 eine abfallende Flanke ist, da Bit 0 des peripheren 
Steuerregisters gleich 0 ist. Diese Konfiguration ist geeignet für zahlreiche Bild¬ 
schirm-Terminals, die eine vollständige Quittierung benötigen 

6) Ein Ausgangsport mit zwischengespeichertem Steuerbit aktiv-Low (zwi¬ 
schengespeicherter Ausgang oder Pegel-Ausgang). Ein derartiges Aus¬ 
gangsbit kann zum Ein- oder Ausschalten eines peripheren Gerätes oder 
zum Steuern seiner Betriebsart dienen. 

LDA # $FF .MACHE PORT-B-LEITUNGEN ZU AUS- 

; GÄNGEN 

STA VIADDRB 

LDA #%11000000 ;STEUERLEITUNG 2 - ZWISCHENGESPEI- 
; CHERTER NULLPEGEL 

STA VIAPCR 

Bit 7 = 1, um die Steuerleitung CB2 zu einem Ausgang zu machen, Bit 6 = 1, um 
es zu einem Pegel zu oder einem gespeicherten Bit zu machen, und Bit 5 = 0, 
um den Pegel aktiv null zu machen. Dieses Bit wird nicht durch Operationen am 
E/A-Port oder Ausgangsregister beeinflußt. Sein Wert kann durch Ändern von 
Bit 5 des peripheren Steuerregisters geändert werden, d.h., 


LDA 

VIAPCR 


ORA 

#%00100000 

;MACHE PEGEL EINS 

STA 

VIAPCR 


LDA 

VIAPCR 


AND 

# %11011111 

;MACHE PEGEL NULL 

STA 

VIAPCR 



Sie können die Konfiguration zur Erzeugung eines Impulses mit aktiv High oder 
aktiv Low verwenden, oder zum Liefern von Impulsen mit software-gesteuerten 
Längen. 


BEISPIELE FÜR VIA¬ 
KONFIGURATIONEN 


Der kurze Impuls auf der Steuerleitung CB2 wird nach jeder Ausgangs Opera¬ 
tion auftreten. Bit 7 des peripheren Steueregisters ist 1 um CB2 zu einem Aus¬ 
gang zu machen, Btt 6 ist 0, um CB2 zu einem Impuls zu machen, und Bit 5 ist 1, 
um CB2 zu einem kurzen Impuls (ein Taktzyklus) z u machen, folgend nach jeder 
Ausgabe. 
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VERWENDUNG DES VIA ZUM TRANSFER VON DATEN 

Sobald der VIA konllgunert wurde, können Sie seine Daten¬ 
register wie jeden anderen Speicherplatz verwenden (so 
wie beim PIA). Der gebräuchliche Weg zum Transferieren 
von Daten. Status und Steuerung geschieht mit den Befehlen Load Accumula- 
tor. Store Accumulator, Bit Test und Compare. Beachten Sie. daß das Aus¬ 
gangsregister A auf zwei Wegen adressiert werden kann - einer mit Quittierung 
(Adresse 1) und einer ohne Adressierung (Adresse F). Die Adresse ohne Quit¬ 
tierung gestattet Ihnen, CA1 unabhängig von dem mit dem E/A-Por A verbun¬ 
denen peripheren Baustein zu verwenden. Diese Steuerleitung könnte für einen 
Alarm, Takt-Eingang, zur Steuerung eines Interface, oder als zusätzlicher 
Steuereingang von anderen peripheren Geräten verwendet werden. Das Unter¬ 
brechungsflag für diesen Eingang kann direkt gelöscht werden, indem die ent¬ 
sprechenden Bits im Unterbrechungsflag-Register gelöscht werden (siehe Bild 
11-11). Die andere Adresse für das Ausgangsregister A und die unabhängigen 
Betnebsart für die Steuerleitungen CA2 und CB2 gestatten die Verwendung von 
Steuerleitungen, ohne sich über die automatischen Quittierungs-Eigenschaften 
des VIA kümmern zu müssen. 


VIA-EINGABE/ 

AUSGABE 


UNTERBRECHUNGSFLAG-REGISTER DES VIA 


Wir haben das VIA-Unterbrechungsflag-Register 
(siehe Bild 11-11) bei verschiedenen Gelegenheiten 
erwähnt. Die Tabelle in Bild 11-11 erklärt die Be¬ 
deutung der verschiedenen Bits (Bit 7 ist ein univer¬ 
selles Unterbrechungs-Anforderungsbit. das 1 ist, wenn irgendeine Unterbre¬ 
chung sowohl aktiv wie freigegeben ist). 

Jedes der Flags Im Unterbrechungsflag-Register kann ausdrücklich durch 
Schreiben einer logischen 1 in die entsprechende Bit-Position gelöscht wer¬ 
den. Dieses Verfahren ist dann nützlich, wenn die Steuerleitungen unabhängig 
von den Datenports verwendet werden (wie bei der unabhängigen Eingabe-Be¬ 
triebsart, beschrieben in den Tabellen 11-8 und 11-9), oder wenn als Reaktion 
auf das zu setzende Flag kein Datentransfer tatsächlich erforderlich ist. Einige 
Beispiele für ein ausdrückliches Löschen der Flags sind: 

LDA #%00000010 

STA VIAIFR ;LÖSCHE CAI-UNTERBRECHUNGSFLAG 

LOA #%00001000 

STA VIAIFR iLÖSCHE CB2-UNTERBRECHUNGSFLAG 

LDA #%11111111 

STA VIAIFR ;LÖSCHE ALLE UNTERBRECHUNGSFLAGS 

Der in Bit 7 geschriebene Wert ist ohne Bedeutung, da dieses Flag nicht aus¬ 
drücklich von der CPU gesetzt oder gelöscht werden kann. 

Die Bits 0, 1, 3 und 4 des VIA-Unterbrechungsflag-Registers dienen häufig als 
Quittierungs-Statusbit, wie etwa Data Ready oder Peripheral Ready. Sie können 
ihre Werte durch entsprechendes Maskieren oder Schiebe-Operationen prüfen. 


UNTERBRECHUNGS¬ 

FLAG-REGISTER 

DESVIA 


LDA 

VIAIFR 


AND 

#%00000010 

;IST CA1-FLAG GESETZT? 

BNE 

DEVRDY 

:JA, BAUSTEIN BEREIT 

LDA 

VIAIFR 


AND 

#%00010000 

;IST CB1 -FLAG GESETZT? 

BNE 

DEVRDY 

;JA. BAUSTEIN BEREIT 


Das Flag wird automatisch durch Lesen oder Schreiben des entsprechenden 
Ports oder durch spezielles Löschen des Bits im Unterbrechungsflag- 
Register gelöscht. Das folgende Programm wird auf ein Ready-Flag warten, 
das dem Eingang CA1 für ein High zugeordnet ist: 

WAITR LDA VIAIFR 

AND #%00000010 ;ISTCA1-FLAG GESETZT? 

BEQ WAITR ;NEIN, WARTE 

Wie könnten Sie dieses Programm ändern, um die Ready-Leitungen zu hand¬ 
haben, die zu CA2, CB1 oder CB2 geführt sind? 

Beachten Sie, daß die Flags gesetzt bleiben, bis irgendeine Operation sie 
löscht. Wenn keine Operation tatsächlich erforderlich ist. kann irgendeine 
"Blind" (dummy)-Operation (wie das Lesen des Ports und Löschen der Daten) 
erforderlich sein, um einfach das Flag zu löschen. Seien Sie besonders sorgfäl¬ 
tig in Fällen, bei denen die CPU nicht bereit für Daten ist oder 
keine Ausgangsdaten zu senden hat. Offensichtlich ist in Fällen, bei denen der 
Zweck der Operationen nicht sofort deutlich wird, eine sorgfältige Dokumenta¬ 
tion sehr wesentlich. 
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VIA-ZEITGEBER 9,10 


Wie wir früher beschrieben haben, enthält der VIA zwei 

16-Bit-Zähler/Zeitgeber. Diese Zeitgeber werden wie folgt 

gehandhabt: 

1) Sie können wie sechs Speicherplätze gelesen oder geschrieben werden, 
vier für Zeitgeber 1 und zwei für Zeitgeber 2 (siehe Tabelle 11 -7). 

2) Ihre Betriebsarten werden durch die Bits 5, 6 und 7 des Hilfs-Steuer¬ 
registers bestimmt (siehe Bild 11-10), 

3) Ihr Status kann durch Prüfen der Bits 5 und 6 des Unterbre- 
chungsflags-Registers bestimmt werden (siehe Bilkd 11-11). 

Die Zeitgeber können wie folgt verwendet werden: 

1) Zur Erzeugung eines einzelnen Zeitintervalls. Der Zeitgeber muß mit der An¬ 
zahl der erforderlichen Taktimpulsegeladen werden. 

2) Zum Zählen von Impulsen am Anschluß PB6 (nur Zeitgeber 2). Der Zeitgeber 
muß mit der Anzahl der zu zählenden Impulse geladen werden. Diese Ver¬ 
wendung von PB6 nimmt den Vorrang über seine normale Verwendung als 
E/A Anschluß ein. 

3) Zur Erzeugung kontinuierlicher Zeitintervalle (nur Zeitgeber 1), zur Verwen¬ 
dung in Echtzeit-Anwendungen. Der Zeitgber muß mit der Anzahl der Tak¬ 
timpulse pro Intervall geladen werden . 

4) Zur Erzeugung eines einzelnen Impulses oder einer aufeinanderfolgenden 
Serie von Impulsen am Anschluß PB7 (nur Zeitgeber 1). Der Zeitgeber muß 
mit der Anzahl der Taktimpulse pro Intervall geladen werden. Diese Verwen¬ 
dung von PB7 übernimmt den Vorrang über seine normale Verwen¬ 
dung als ein E/A-Anschluß. 
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ARBEITSWEISE DES ZEITGEBERS 2 IM VIA 6522 


Zeitgeber 2 ist einfacher als Zeitgeber 1 und kann nur zur Erzeugung eines 
einzelnen Zeitintervalls verwendet werden (die monostabile Betriebsart) oder 
zur Zählung von Impulsen an Anschluß PB6. Bit 5 des Hilfs-Steuerregisters 
wählt die Betriebsart aus; 

Bit 5 = 0 für monostabilen Betrieb, 1 für das Zählen von Impulsen. 

Der 16 Bit-Zeitgeber belegt zwei Speicherplätze (siehe Tabelle 11-7). Die erste 
Adresse wird zum Lesen oder Schreiben der acht höchstwertigen Bits verwen¬ 
det. Das Lesen dieser Adresse löscht auch das Unterbrechungsflag des Zeitge¬ 
bers 2 (Bild 11-11). Die zweite Adresse wird zum Lesen oder Schreiben der acht 
höchstwertigen Bits verwendet Das Schreiben in diese Adresse lädt die Zähler, 
löscht das Unterbrechungsflag des Zeitgebers 2 und startet die zeitliche Opera¬ 
tion Der Abschluß dieser Operation setzt das Unterbrechungsflag des Zeitge¬ 
bers 2 (Bit 5 des Unterbrechungsflag-Registers, wie in Bild 11-11 gezeigt). 

Beispiele für die Arbeitsweise des Zeitgebers 2 wären folgende: 

1) Warten 1024 (0400, 6 ) Taktimpulse 

LDA #0 ;BRINGE ZEITGEBER 2 IN MONOSTABILE 

: BETRIEBSART (BIT 5 = 0) 

STA VIAACR 

STA VIAT2L ;MACHE IMPULSELÄNGE 0400HEX 

LDA # 4 

STA VIAT2H ;STARTE ZEITGEBER-INTERVALL 

LDA #%00100000 ;HOLE MASKE FÜR UNTERBRECHUNGS- 
; FLAG VON ZEITGEBER 2 

WAITD BIT VIAIFR ;IST FLAG VON ZEITGEBER 2 GESETZT? 

BEO WAITD ;NEIN, INTERVALL NICHT BEENDET 

LDA VIAT2L ;JA, LÖSCHE UNTERBRECHUNGSFLAG 

BRK 

Beachten Sie folgende Schritte in diesem Programm: 

a) Versetzen des Zeitgebers in die monostabite Betriebsart durch Löschen von 
Bit 5 des Hilfs-Steuerregisters. 

b) Laden des Zeitgebers mit der Anfangszählung (0400 16 ), erforderlich, um das 
richtige Intervall zu ergeben. Das Laden des MSBs des Zeitgebers startet 
auch die eigentliche Operation. 

c) Warten bis das Intervall abgeschlossen ist. Nach Ablauf der Zeit wird Bit 5 
des Unterbrechungsflag Registers gesetzt. 

d) Löschen des Unterbrechungsflags, so daß es nicht andere Operationen 
stört. Der Befehl LDA VIAT2L führt diese Funktion aus. 
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2) Erzeugen einer Verzögerung, deren Länge durch 10 Impulse am Anschluß 
PB6 gegeben ist. 


LDA 

STA 

LDA 

STA 

LDA 

STA 

LDA 

STA 

LDA 

WAITD BIT 
BEQ 
LDA 
BRK 


#0 

VIADDRB MACHE PORT B ZU EINGÄNGEN 

#%00100000 ;BRINGE ZEITGEBER 2 IN IMPULSZÄHL¬ 
BETRIEBSART (BIT 5 - 1) 

VIAACR 

#10 ;MACHE IMPULSZÄHLUNG 10 

VIAT2L 


#0 

VIAT2H 
#%00100000 

VIAIFR 

WAITC 

VIAT2L 


;STARTE IMPULSZAHLUNG 

;HOLE MASKE FÜR UNTERBRECHUNGS- 

; FLAG VON ZEITGEBER 2 

;IST FLAG VON ZEITGEBER 2 GESETZT? 

;NEIN, ZÄHLUNG NICHT BEENDET 

;JA, LÖSCHE UNTERBRECHUNGSFLAG 


Dieses Programm ist das gleiche wie das vorausgehende Beispiel, mit Ausnah¬ 
me, daß die Betriebsart von Zeitgeber 2 unterschiedlich ist. Hier könnte das Ein¬ 
gangssignal am Anschluß PB6 ein periodischer Takt oder eine Leitung sein, die 
einfach bei jedem Auftreten irgendeiner externen Operation gepulst wird. 


ARBEITSWEISE DES ZEITGEBERS 1 IM VIA 6522 

Der Zeitgeber 1 hat vier Betriebsarten (siehe Bild 11-10), die die Erzeugung 
eines einzelnen Zeitintervalis (monostabile Betriebsart) oder einer auf¬ 
einander folgenden Serie von Intervallen (freilaufende Betriebsart) gestatten. 

Ferner kann jede Lade-Operation einen Ausgangsimpuls an PB7 erzeugen, 
der zum Steuern externer Hardware verwendet werden kann. Die Bits 6 und 7 
des Hilfs-Steuerregisters bestimmen die Betnebsart des Zeitgebers 2 wie 
folgt 

Bit 7 -1 zum Erzeugen von Ausgangsimpulsen an Anschluß PB7, 0 zum Sper¬ 
ren derartiger Impulse (in der freilaufenden Betriebsart wird PB7 jedesmal, 
wenn der Zähler Null erreicht invertiert). 

Bit 6 - 1 fürfreilaufende Betriebsart, 0 für monostabile Betnebsart. 

Der Zeitgeber 1 belegt vier Speicheradressen (siehe Tabelle 11-7). Die ersten 
beiden Adressen werden zum Lesen oder Schreiben der Zähler verwen¬ 
det. Das Schreiben in die zweite Adresse lädt die Zähler, löscht das Unterbre¬ 
chungsflag des Zeitgebers 1, und stailet die zeitliche Operation Die näch¬ 
sten zwei Adressen werden zum Lesen oder Schreiben in die Speicher ohne 
Beeinflussung der Zähler verwendet. Dies gestattet die Erzeugung komplexer 
Spannungen in der freilaufenden Betriebsart Das Schreiben in die höchstwerti¬ 
gen Bits der Zwischenspeicher löscht auch das Unterbrechungsflag von Zeitge¬ 
ber 1. 


Beispiele für die Arbeitsweise des Zeitgebers 1 wären folgende: 

1) Warte auf das Ablaufen von 4096 (1000 16 ) Taktimpulsen, vor der Erzeugung 
eines Ausgangssignals am Anschluß PB7. 


WAITD 


LDA 

#0 

STA 

VIAACR 

STA 

VIAT1L 

LDA 

#$10 

STA 

VIAT1 CH 

LDA 

#%01000000 

BIT 

VIAIFR 

BEQ 

WAITD 

LDA 

VIAT1L 

BRK 



BRINGE ZEITGEBER 1 IN MONOSTABILE 
BETRIEBSART, KEINE AUSGABE¬ 
BETRIEBSART 

IMPULSLÄNGE = 1000 HEX 

STARTE ZEITGEBER-INTERVALL 
HOLE MASKE FÜR UNTERBRECHUNGS¬ 
FLAG VON ZEITGEBER 1 
IST FLAG VON ZEITGEBER 1 GESETZT? 
NEIN, INTERVALL NICHT ABGESCHLOSSEN 
JA, LÖSCHE UNTERBRECHUNGSFLAG VON 
ZEITGEBER 1 


Die einzigen Änderungen gegenüber dem Programm für Zeitgeber 2 sind die 
unterschiedlich verwendeten Adressen zum Laden der Impulslänge und die un¬ 
terschiedliche Bit-Position (Bit 6 anstatt von Bit 5) für die Prüfung des Unterbre¬ 
chungsflags. 
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2) Erzeuge eine Unterbrechung alle 2048 (0800 16 ) Taktimpulse und erzeuge 
eine aufeinanderfolgende Serie von Zyklen am Anschluß PB7 mit einer hal¬ 
ben Breite von 1024 Taktimpulsen. 


LDA 

#$FF 

STA 

VIADDRB 

LDA 

#%11000000 

STA 

V1AACR 

LDA 

#0 

STA 

VIAT1L 

LDA 

#8 

STA 

BRK 

VIAT1CH 


.MACHE PORT-B-LEITUNGEN ZU AUS- 
; GÄNGEN 

BRINGE ZEITGEBER 1 IN KONTINUIERLICHE 

BETRIEBSART MIT AUSGABE ZU PB7 

;MACHE IMPULSLÄNGE 0800 HEX 


;STARTE ZEITGEBER-INTERVALLE 


Diese Routine wird eine aufeinanderfolgende Serie von Intervallen erzeugen, die 
durch das Setzen des Unterbrechungsflags des Zeitgebers 1 markiert sein wer¬ 
den (Bit 6 des Unterbrechungsflag-Regislers) Das Hauptprogramm kann auf 
das Auftreten jeder Unterbrechung (mit der Warte-Routine von Beispiel 1) Aus¬ 
schau halten, oder (empfindlicher) das Ende jedes ZeiTmtervalles kann eine Un¬ 
terbrechung erzeugen (siehe Kapitel 12). Der Pegel an PB7 wird am Ende jedes 
Zeitintervalles invertieil werden (er wird Low werden, wenn das erste Intervall 
startet) Zeitgeber 1 wird kontinuierlich mit Weilen in den Zwischenspeicher lau¬ 
fen, die automatisch zurück in den Zähler geladen werden, jedesmal wenn die 
Zähler Null erreichen. 


DIE MEHRFUNKTIONS-BAUSTEINE 6530 UND 6532 


Die Bausteine 6530 und 6532 enthalten Spei¬ 
cher sowie E/A-Ports. Sie werden manchmal als 
Kombinations-Chips, Mehrfunktions-Hilfsbau- 
steine oder TIMER-Chips (RIOTs) bezeichnet. 

Der Baustein 6530 beinhaltet: 

• 1024 Byles ROM 

• 64 Byles RAM 

• Zwei 8 Bit-E/A-Ports (A und B) obwohl die Pins 
5 bis 7 von Port B häufig für Chip-Auswahl und 
Unterbrechungs-Ausgabe veiwendet werden. 

• Ein 8-Bit-Zeitgeber 

Bild 11-12 ist ein Blockschaltbild des Bausteins 6530 und Tabelle 11-10 be¬ 
schreibt seine inlerne Adressierung. Der Baustein 6532 hat: 

• 128 Bytes RAM 

• Zwei 8-Bit-E/A-Poits (A und B) obwohl Pin 7 von Port A häufig als ein Tastein¬ 
gang verwendet wird, vergleichbar mit den Anschlüssen CA1 oder CB1 eines 
Bausteines 6520 oder 6522. 

• Ein 8-Bit-Zeitgeber 

Bild 11-13 ist ein Blockschaltbild des Bausteins 6532 und Tabelle 11-11 be¬ 
schreibt seine interne Adressierung Beachten Sie, daß Bausteine 6532 kein 
ROM enthalten. 

Die folgenden Eigenschaften der Bausteine 6530 und 6532 sollten beachtet 
werden: 

1) Sie enthalten weder irgendwelche bestimmten Steuerleitungen, obwohl Pin 7 
von Port A eines Bausteines 6532 für diesen Zweck verwendet werden kann. 

2) Beide enthalten einen einzelnen 8-Bit-Zeitgeber mit einem Vorteiler, der es 
gestattet. Zeit-Intervalle mit Faktoren von 1,8, 64 oder 1024 Taklimpulsen zu 
multiplizieren. Der Zeitgeber kann daher zur Lieferung von Zeillntervallen 
verwendet werden, die wesentlich länger als die grundlegende 256 Taktzahl 
sind. 

3) Das Ende des Zeilinlervalls bewirkt entweder eine Unterbrechung oder setzt 
ein Ftag. das gelesen werden kann. 

Die Bausteine 6530 und 6532 werden in den bekannten Ein-Platinen-Mikro- 
computer wie KIM, VIM. SYM und AIM-65 verwendet. 


6530 UND 6532 
MEHRFUNKTIONS¬ 
BAUSTEINE 
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Bild 11 -12. Blockschaltbild des Mehrlunktions-Bausteins 6530. 


Tabelle 11-10 Interne Adressierung des Mehrfunknons Bausteins 6530 


Primäre Auswahl 

Adressierte Speicherplätze 

RS 


E/A* 

Zeil* 

geber- 

Aub- 

wahr 

1 

X 

X 

AO 

- A9 adressiert direklemes der 1024 ROM Bytes 

0 

1 

0 

AO - A5 adressiert direki eines der 64 RAM-Byles 




Sekundäre 






Auswahl 














A3 

A2 

AI 

□ 


0 

0 

1 

X 

0 

0 

0 

Zugriff aul E/A-Port A 

0 

0 

1 

a 

0 

O 

1 

Zugriff aul Datennchtungs-Register von E/A-Porl A 

0 

0 

1 

□ 

0 

n 

0 

Zugrilf aul E/A*Port B 

0 

0 

1 

□ 

0 

n 

1 

Zugnlf aul Dalenrichtungs-Register von E/A-Porl B 

0 

0 

IW 

LI 

> 

X 

X 

Sperre IRO 

0 

0 

IW 

1 

1 

X 

X 

Gib IflO frei 

0 

0 

iw 

X 

1 


0 

Schreibe zu Zeitgeber, dann dekrem alle ^2-lmpulse 

0 

0 

IW 

X 

1 

P, ■ 

1 

Schreibe zu Zeitgeb . dann dekrem. alle 8^2-lmp- 

0 

0 

IW 

X 

1 

' 

0 

Schreibe zu Zeilgeb , dann dekrem alle 64 $ 2 -tm p. 

0 

0 

IW 

X 

1 

1 

1 

Schreibe zu Zeitgeb . dann dekrem. alle 1024 <^2*lmp 

0 

0 

IR 

X 

1 


0 

Lies Zeitgeber 

0 

0 

IR 

X 

1 

X 

1 

Lies Unlerbrechungs-Flags 


‘RAM-Auswahl und E/A- Auswahl sind wahr” wenn 1 oder "falsch wOnnO Wahr und falsch snd 
Funktionen Ihrer Sbezdikalion Sie können die Kombination von Adressen Leitungen spezifi¬ 
zieren. die eineLeilungs-Bedmgung mit ' wahr' 1 erzeugen 


X bedeutet "beliebig Bits können 0 oder 1 sein. 

1 R bedeutet Auswah i wahrend eines Lesens 
IW bedeutet Auswahl während eines Schreibens 
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Bild 11-13. Blockschallbild des Mehrfunktions-Bausteins 6532. 


Tabelle 11-11 Inlerne Adressierung des Mehrfunktions-Bausteins 6532 



RAM* 

Auswahl 

E/A-Zeit- 

geber- 

Auswahl 

A4 

A3 

A2 

AI 

A0 

Interpretation 

1 

0 

X 

X 

X 

X 

X 

A0 A6 adressiert direkt eines der 128 PAM-Bytes 

0 

1 

X 

X 

0 

0 

0 

Zugrul aul E/A Port A 

0 

1 

X 

X 

0 

0 

1 

Zugriff aul Oatennchlungs Register des E/A*Ports A 

0 

1 

X 

X 

0 

1 

0 

Zugriff aul E/A-Port B 

0 

1 

X 

X 

0 

1 

1 

Zugnlf aul Dalennchlungs-Register des E/A*Porls B 

0 

IW 

1 

0 

1 

X 

X 

Sperre IRO 

0 

IW 

1 

1 

1 

X 

X 

GlklHÖtr»! 

0 

IW 

1 

X 

1 

0 

0 

Schreibe zu Zeitgeber, dekremenjiere alle fi2-lmpulse 

0 

IW 

1 

X 

1 

0 

1 

Schreibe zu Zeitgeber, dek/em, alle 8 $2-lmp 

0 

1 w 


X 

1 

1 

0 

Schreibe zu Zeilgeber.dekrem alle €4 02-lmp 

0 

tw 


X 

1 

1 

1 

Schreibe zu Zeitgeber, dekrem alle 1024 02-lmp 

0 

1 R 

x 

X 

1 

X 

0 

Lies Zeitgeber 

0 

IR 

X 

X 

1 

X 

1 

Lies Unterbrechungs-Flags 

0 

IW 

0 

X 


X 

0 

Fordere Unterbrech bei High-aut-Low-Uberg v PA7an 

0 

IW 

0 

X 


X 

1 

Fordere Unlerbrech bei Low-aul-High-Llberg v PA7 an 

0 

IW 

0 

X 

1 

0 

X 

Gib PA7 Unterbrechungs-Anforderung frei 

0 

tw 

0 

X 

1 

1 

X 

Sperre PA7-Unlerbrechungs-Anforderung 


X bedeutet "beliebig". Bils können 0 oder 1 sein. 

IR bedeulelLese-Zugrifl 1 W bedeutet Schreib-Zugrill 


BEISPIELE 
Eine Taste 


Zweck: Die Anpassung einer einzelnen Tasle an einen Mikroprozessor 6502 
mittels eines VIA 6522. Die Taste ist ein mechanischer Schalter, der 
(einen Logikpegel "0") durch einen geschlossenen Kontakt liefert, wenn 
die Taste betätigt wird. 

Bild 11-14 zeigt die erlorderliche Schaltung für die Anpassung der Taste. Sie 
verwendet ein Bit eines PIA 6522, der als Puffer arbeitet Es ist keine Zwischen¬ 
speicherung erforderlich, da die Tasle für mehrere CPU-Zyklen geschlossen 
bleibt. Das Drücken der Taste legt das Eingangs-Bit des VIA an Masse. Der Pull- 
up-Widerstand sichert daß das Eingangs-Bit ”1" ist, wenn die Taste nicht ge¬ 
druckt ist. 



Bild 11-14. Eine Tasten-Schaltung 


11-51 




















Queliprogramm: 


Programmbeispiele: 

Wir wollen zwei Aufgaben mit dieser Schaltung ausführen. Diese sind: 

1) Setze einen Speicherplatz, basierend auf den Zustand der Taste. 

2) Zähle, wie oft die Taste gedrückt wurde. 

Aufgabe 1: Setze Speicherplatz 0040 auf 1. wenn die Taste nicht gedrückt wird, 
und auf 0. wenn sie gedrückt wird. 

Beispiele: 

1) Taste offen (d.h., nicht gedrückt) 

Ergebnis: (0040)- 01 

2) Taste geschlossen (d.h., gedrückt) 

Ergebnis (0040)= 00 

Fiußdiagramm: 



LDA 

#0 


STA 

VIAPCR 

.MACHE ALLE STEUERLEITUNGEN ZU EIN 

: Gängen 

STA 

VIADDRA 

;MACHE PORT-A-LEITUNGEN ZU EIN¬ 
GÄNGEN 

STA 

$40 

;MARKE =0 

LDA 

VIAORA 

;LIES TASTEN-POSITION 

AND 

# MASK 

;IST DIE TASTE GESCHLOSSEN (LOGISCH 
. NULL?) 

BEO 

DONE 

;JA, ZU DONE 

INC 

DONE BRK 

Objektprogramm: 

$40 

;NEIN, MARKE -1 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) 

0000 

A9 

LDA 

#0 

0001 

00 



0002 

8D 

STA 

VIAPCR 

00031 

00041 

VIAPCR 



0005 

8D 

STA 

VIADDRA 

0006) 

0007 f 

VIADDRA 



0008 

85 

STA 

$40 

0009 

40 



000A 

AD 

LDA 

VIAORA 

000B) 

ooocf 

VIAORA 



OOOD 

29 

AND 

#mask 

000E 

MASK 



000F 

FO 

BEQ 

DONE 

0010 

02 



0011 

86 

INC 

340 

0012 

40 



0013 

00 DONE 

BRK 



Die Adressen VIAPCR (Peripheral Control Register), VIADDRA (Data Direction 
Register A), und VIAORA (Output Register A) hängen davon ab, wie der VIA mit 
Ihrem Mikrocomputer verbunden ist. Die VIA-Steuerleitungen werden in diesem 
Beispiel nicht verwendet. Der Inhalt des peripheren Steuerregisters ist daher 
irrelevant, wir haben jedoch dieses Register vorsichtshalber gelöscht. Wir haben 
angenommen (wie dies gewöhnlich der Fall ist), daß die VIA-Adressen nicht auf 
Seite Null liegen. 
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MASK hängt von dem Bit ab, mit dein die Taste verbunden ist. Es besitzt eine 
Eins in der Tastenposilion und sonst Nullen 


Tasten-Position 

(Bit-Nummer) 

Maske 

Binär 

Hexadezimal 

0 

0000000 1 

01 

1 

00000010 

02 

2 

00000100 

04 

3 

00001000 

08 

4 

00010000 

10 

5 

00100000 

20 

6 

01000000 

40 

7 

10000000 

80 


Wenn die Taste mit Bit 6 oder Bit 7 des VIA Eingangspoil verbunden ist, kann 
das Programm einen Bit-Test-Befehl zu Selzen des Überlaut oder Vorzeichen- 
Bits verwenden und hierbei den Zustand der Taste bestimmen. Zum Beispiel: 


Bit 7 

BIT 

VIAORA 

ISTTASTE GESCHLOSSEN (LOGISCH 
NULL)’ 

BPL 

DONE 

JA, DONE 

Bit6 

BIT 

VIAORA 

IST TASTE GESCHl OSSEN (LOGISCH 
NULL)’ 

BVC 

DONE 

JA, DONE 


Beachten Sie die Verwendung von BVC odei BVS zum Prüfen des Wertes von 
B 1 16 

Wir könnten auch Schiebebefehle verwenden, wenn die Taste mit den Bits 0, 6 
oder 7 verbunden ist. Die Sequenz für Bit 0 lautet: 

LSR VIAORA ;IST TASTE GESCHLOSSEN (LOGISCH 

: NULL)? 

BCC DONE ;JA, DONE 


Aufgabe 2: Zählen der Anzahl der Tasten-Bestätigung 

Zweck: Zähle die Anzahl der Tastenbestätigung durch Inkrementieren des Spei¬ 
cherplatzes 0040 nach jedem Schließen 

Beispiel: 

Das Drücken der Taste zehnmal nach dem Start des Programmes sollte erge¬ 
ben: 

(0040) ->0A 


Anmerkung: Um zu zahlen, wie oft die Taste betätigt wurde, 
muß man sich vergewissern, daß jedes Schließen des Ta- 
sten-Kontaktes auch tatsächlich einen einzelnen Spannungssprung erzeugt. 
Nicht jedes Schließen eines mechanischen Tasten-Kontaktes erzeugt auch tat¬ 
sächlich einen einzelnen Spannungssprung, da die mechanischen Kontakte 
prellen, bevor sie ihre endgültige Lage erreichen Man kann einen monostabilen 
Multivibrator verwenden, um das Prellen zu eliminieren oder man kann dies mit¬ 
tels der Software erledigen. 

Das Programm kann die Taste entprellen, indem es 
nach dem Schließen der Taste wartet. Die erforderli¬ 
che Verzögerung wird Entprellzeit genannt und ist 
Teil der Spezifikationen der Taste. Sie ist typisch einige wenige Millisekunden 
lang. Das Programm sollte die Taste während dieser Periode nicht prüfen, da 
Fehler infolge des Prellens der Taste entstehen könnten. Das Programm kann 
entweder in eine Verzögerungs-Routine eintreten, ähnlich der vorher beschrie¬ 
benen, oder es kann einfach andere Aufgaben während dieses bestimmten Zei¬ 
tintervalls ausführen. 

Auch nach der Entprellung muß das Programm noch warten, bis der momentan 
geschlossene Kontakt wieder geöffnet wird, bevor es nach weiteren 
Tasten-Bestätigungen Ausschau hält. Dieses Verfahren vermeideteine doppelte 
Zählung. Das folgende Programm verwendet eine Software-Verzögerung von 
10 ms, um die Tasten zu entprellen. Man kann auf Wunsch versuchen, die Ver¬ 
zögerung zu variieren oder sie ganz zu eliminieren um festzustellen, was ge¬ 
schieht Um dieses Programm ablaufen zu lassen, muß man das Verzögerungs- 
Unterprogramm in den Speicher einbringen, beginnend beim Speicherplatz 
0030. 


TASTEN¬ 

PRELLEN 


ENTPRELLEN 
DURCH SOFTWARE 


Die Befehle ASL und ROL können mit den Bits 6 oder 7 verwendet werden 
Ändert sich der Inhalt des VIA-Datenregisters wirklich’ Erklären Sie Ihre 
Antwort. 
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Flußdiagramm: 


Objektprogramm: 



Quellprogramm: 



LDA 

#0 



STA 

VIAPCR ;MACHE ALLE STEUER-LEITUNGEN ZU EIN- 




GANGEN 


STA 

VIADDHA ;MACHE PORT A-LEITUNGEN ZU EIN- 




GANGEN 


STA 

$40 

ZÄHLUNG- 0 ZU ANFANG 

CHKCL 

LDA 

VIAORA 



AND 

#MASK 

IST DIE TASTE GEDRÜCKT? 


BNE 

CHKCL 

NEIN, WARTE BIS DIES DER FALL IST 


INC 

$40 

JA, ADDIERE 1 ZUR ZÄHLUNG 


LDY 

#10 ;WARTE 10 MS FÜR ENTPRELLEN 


JSR 

DELAY 


CHKOP 

LDA 

VIAORA 



AND 

#MASK 

IST DIE TASTE NOCH IMMER GEDRÜCKT? 


BEO 

CHKOP 

JA, WARTE AUF LOSLASSEN 


BNE 

CHKCL 

NEIN, HALTE NACH NÄCHSTER 




BETÄTIGUNG AUSSCHAU 


Speicher Adresse 

Speicher-Inhalt 


Befehl 

(Hex) 

(Hex) 


(Mnemonik) 

0000 

A9 


LDA 

#0 

0001 

00 




0002 

8D 


STA 

VIAPCR 

00031 

0004 f 

VIAPCR 




0005 

8D 


STA 

VIADDRA 

0006» 

00071 

VIADDRA 




0008 

85 


STA 

$40 

0009 

40 




OOOA 

AD 

CHKCL 

LDA 

VIAORA 

OOOBI 

OOOCl 

VIAORA 




000D 

29 


AND 

#MASK 

000E 

MASK 




000E 

DO 


8NE 

CHKCL 

0010 

F9 




0011 

E6 


INC 

$40 

0012 

40 




0013 

AO 


LDY 

#10 

0014 

OA 




0015 

20 


JSR 

DELAY 

0016 

30 




0017 

00 




0018 

AD 

CHK*P 

LOA 

VIAORA 

OOlgi 

001AI 

VIAORA 




0018 

29 


AND 

#MASK 

001C 

MASK 




001D 

EO 


BEO 

CHKOP 

001E 

E9 




001F 

DO 


BNE 

CHKCL 

0020 

E9 





Die drei Befehle, die mit der Markierung CHKOP beginnen, werden zum Warten 
verwendet, bis die Taste wieder losgelassen wird. 

Natürlich benötigen wir nicht wirklich einen VIA für dieses einfache Interface. Ein 
adressierbares Tristate-Puffer würde die Aufgabe mit wesentlich geringeren Ko¬ 
sten erfüllen. 
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Ein Kippschalter 

Zweck: Anpassung eines einpoligen Kippschalters mit zwei Stellungen an einen 
Mikroprozessor 6502. Der Kippschalter ist ein mechanischer Baustein, 
oder in einer von zwei möglichen Stellungen (NC - geschlossen. NO- 
offen) liegt. 

Bild 11-15 zeigt die Schaltung, die zur Anpas¬ 
sung des Schalters erforderlich ist. Wie bei der 
Taste verwendet der Schalter ein Bit des VIA 
6522, das als adressierbarer Pufler dient. 

Anders als bei der Taste kann der Schalter in einer der beiden Positionen belas¬ 
sen werden. Typische Programm-Auf gaben sind das Bestimmen der Schalter- 
Position und die Feststellung, ob sich die Position geändert hat. Es kann entwe¬ 
der ein monostabiler Multivibrator mit einer Impulslänge von einigen Millisekun¬ 
den oder ein paar kreuzgekoppelter NAND-Gatter (siehe Bild 11 -16) verwendet 
werden, um einen mechanischen Schalter zu entprellen. 



Bild 11-15. Ein Interface lur einen Kippschalter 


ENTPRELLUNG MIT 
KREUZ GEKOPPELTEN 
NAND-GATTERN 


♦5 V 



Bild 11-16 Eine Entpreii-Schaltung mit kreuzgekoppelten NAND-Gattern. 


Die Schaltungen werden einen einzelnen Spannungssprung oder Impuls infolge 
der Änderung der Schalterpositionen erzeugen, auch wenn der Schalter prellt, 
bevor er sich in seiner neuen Position befindet, 

Programmbeispiel; 

Wir wollen zwei Aufgaben unter Verwendung dieser Schaltung ausführen. Diese 
sind: 

1) Setze einen Speicherplatz auf Eins, wenn der Schalter geschlossen ist. 

2) Selze einen Speicherplatz auf Eins, wenn sich der Zustand des Schalters än¬ 
dert. 

Aufgabe 1: Warten auf das Schließen des Schalters. 

Zweck; Der Speicherplatz 0040 ist Null bis der Schalter geschlossen wird und 
wird dann auf Eins gesetzt. Das heißt, der Prozessor löscht den Spei¬ 
cherplatz 0040, wartet auf das Schließen des Schalters und setzt dann 
den Speicherplatz 0040 auf Eins. 

Der Schalter könnte als Run/Ralt markiert werden, da der Prozessor 
nicht weiterläuft, bis der Schalter geschlossen wird. 

Flußdiagramm: 
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Quellprogramm: 


LDA #0 
STA VIAPCR 

STA VIAODRA 

STA $40 

WAITC LDA VIAORA 
AND # MASK 
BNE WAITC 
INC $40 
BRK 


MACHE ALLE STEUER-LEITUNGEN ZU 
EINGÄNGEN 

MACHE PORT A-LEITUNGEN 
ZU EINGÄNGEN 
MARKE - NULL 
LIES SCHALTERSTELLUNG 
IST DER SCHALTER GESCHLOSSEN (0)? 
NEIN, WARTE 
JA, MARKE - EINS 


Objektprogramm: 
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Aufgabe 2; Warten aul Änderung der Schalterstellung. 


Der Speicherplatz 0040 verbleibt Null, bis sich die Schalterstellung ändert und 
wird dann auf 1 gesetzt. Das heißt, der Prozessor wartet bis zur Änderung der 
Schalterstellung, und setzt dann den Speicherplatz 0040 auf Eins. 

Flußdiagramm: 



Quellprogramm: 


LDA #0 
STA VIAPCR 

STA VIADDRA 

STA $40 
LDA VIAORA 
AND # MASK 
STA $41 

WAITCH LDA VIAORA 
AND #MASK 
CMP $41 

BEO WAITCH 
INC $40 
BRK 


;MACHE ALLE STEUERLEITUNGEN ZU 
. EINGÄNGEN 

MACHE PORTA-LEITUNGEN ZU 

; EINGÄNGEN 

lMARKE-0 

;HOLE ALTE SCHALTERSTELLUNG 


;HOLE NEUE SCHALTERSTELLUNG 

;SIND DIE NEUE UND DIE ALTE STELLUNG 
; GLEICH? 

;JA, WARTE 
;NEIN, MARKE- EINS 
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Objektprogramm: 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) 

0000 

A9 

LDA 

#0 

0001 

00 



0002 

8D 

STA 

VIAPCR 

00031 

VIAPCR 



0004t 




0005 

8D 

STA 

VIADDRA 

00061 

VIADDRA 



00071 




0008 

85 

STA 

$40 

0009 

40 



000A 

AD 

LDA 

VIAORA 

OOOBI 

VIAORA 



oooct 




0000 

29 

AND 

#MASK 

000E 

MASK 



000F 

85 

STA 

$41 

0010 

41 



0011 

AD 

WAITCH LDA 

VIAORA 

0012t 

VIAORA 



00131 




0014 

29 

AND 

#MASK 

0015 

MASK 



0016 

C5 

CMP 

$41 

0017 

41 



001B 

FO 

B£Q 

WAITCH 

0019 

F7 



001A 

E6 

INC 

$40 

001B 

40 



001C 

00 

8RK 



Eine Subtraktion oder Exklusiv-ODER-Operation könnte den Vergleich 
(Compare) im Programm ersetzen. Jeder dieser Belehle würde jedoch den In¬ 
halt des Akkumulators ändern. Die Exklusiv-ODER-Operalion wäre sehr nützlich, 
wenn mehrere Schalter mit den gleichen VIA verbunden wären, da es ein Bit tur 
jeden Schalter erzeugen würde, der seinen Zustand geändert hat. Wie würden 
Sie dieses Programm neu schreiben, damit der Schalter durch die Software ent- 
prellt wird? 


Ein Schalter mit mehreren Stellungen (Drehschalter, Wahl¬ 
schalter, oder Daumenrad-Schalter) 

Zweck: Anschluß eines Schalters mit mehreren Stellungen an einen Mikropro¬ 
zessor 6502. Die Leitung, die der Schalterposilion entspricht, wird geer¬ 
det, während die anderen Leitungen High sind (logisch 1) 

Bild 11-17 zeigt die erorderliche Schaltung zum Anschließen eines achtstelligen 
Schalters Der Schalter verwendet alle acht Datenbits eines Ports eines VIA. Ty¬ 
pische Aulgaben sind das Bestimmen der Schalterposilion und Prüfung, ob Sich 
diese Stellung geändert hat oder nicht. Es müssen zwei spezielle Situationen 
verarbeitet werden 

1) Der Schalter belindet sich zeitweise zwischen den Positionen, so daß keine 
Leitungen geerdet sind 

2) Der Schalter hat seine endgültige Lage noch nicht erreicht 

Die erste dieser beiden Möglichkeiten kann durch Warten verarbeitet werden, 
bis alle Eingänge nicht alles Einsen sind, d.h., bis eine Schalterleilung an Masse 
liegt. Wir können die zweite Möglichkeit durch neuerliches Prüfen der Schalter 
nach einer Verzögerung (etwa 1 oder 2 Sekunden) verarbeiten und die Einga¬ 
ben nur akzeptieren, wenn sie gleich bleiben Diese Verzögerung wird gewöhn¬ 
lich die Empfindlichkeit des Systems gegenüber den Schaltern nicht beeinflus¬ 
sen. Wir können auch einen anderen Schalter (z.B. einen Lade-Schalter) ver¬ 
wenden. um dem Prozessor mitzuteilen, wann der Wahlschalter gelesen werden 
sollte. 

Programmbeispiete: 

Wir wollen zwei Aufgaben für die Schaltung in Bild 11-17 lösen. Diese sind: 

a) Beobachten des Schalters, bis er sich in einer endgültigen Position befindet, 
dann die Position bestimmen und ihren Binärwert in einen Speicherplatz ab- 
legen. 

b) Warten auf die Änderung der Schalterposition, dann die neue Position in ei¬ 
nen Speicherplatz ablegen. 

Wenn sich der Schalter in einer bestimmten Lage befindet, so wird die Leitung 
von dieser Position über die gemeinsame Leitung an Masse gelegt. Pullup- 
Widerstände sind gewöhnlich an allen Eingangsleilungen eriorderlich, um Pro¬ 
bleme zu vermeiden, die durch Rauschen verursacht werden. 
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Bild 11-17. Ein Inlerface lür einen mehrstelligen Schalter. 


Aufgabe 1: Bestimmen einer Schalterposition 

Zweck: Das Programm wartet, bis sich der Schalter in einer endgültigen Posi¬ 
tion befinde! und plaziert dann die Nummer dieser Position in den Spei¬ 
cherplatz 0040. 

Tabelle 11-12 enthält den Zusammenhang zwischen den Dateneingängen und 
den Schalterpositionen. 


Tabelle 11-12. Daten-Eingang gegen Schalter-Position. 


Switch Position 

Data Input 

Binary 

Hax 

0 

11111110 

FE 

1 

11111101 

FD 

2 

11111011 

FB 

3 

11 110111 

F7 

4 

11101111 

EF 

5 

11011111 

CF 

6 

10111111 

BF 

7 

01111111 

7F 


Beachten Sie, daß dieses Schema nicht sehr effizient ist, da es acht Bits 
benötigt, um zwischen acht verschiedenen Positionen zu unterscheiden. 


VERWENDUNG 
EINES TTL- 
CODIERERS 


Em TTL- oder MOS-Codierer konnte die Anzahl der beno- 
hgten Bits verringern Bild 11-18 zeigt eine Schaltung, die 
den TTL-8-zi>3-Codierer 74LS148 verwende! 15 . Wir ver 

binden die Schalter-Ausgänge in umgekehrter Reihenfolge >__ 

da der Baustein 74LS148 Eingänge und Ausgänge besitzt die aktiv Low sind 
Das Ausgangssignal der Codierschaltung ist eine 3-Bit Darstellung der Schal¬ 
erposition. Zahlreiche Schalter besitzen derartige Codierer sodaß 9 sie automa 

" e,er " 9eW ° h "" Ch 



Bild 11-18, Ein mehrstelliger Schalter mit einem Codierer 
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Der Codierer erzeugt Ausgangssignale, die aktiv Low sind, so daß beispielswei¬ 
se die Schalterslellung 5. die mil dem Eingang 2 verbunden isl. ein Ausgangs¬ 
signal von 2 in negativer Logik (oder 5 in positiver Logik erzeugt. Sie können 
die doppelte Negation selbst prüfen 

Flußdiagramm: 
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Quellprogramm: 



LDA 

#0 



STA 

VIAPCR 

;MACHE ALLE STEUER-LEITUNGEN 




; ZU EINGÄNGEN 


STA 

VIADDRA 

;MACHE ALLE PORT-A-LEITUNGEN 




ZU EINGÄNGEN 

CHKSW 

LDA 

VIAORA 



CMP 

#$FF 

;IST SCHALTER IN EINER POSITION? 


BEQ 

CHKSW 

NEIN, WARTE AUF EINE SCHALTER- 




; STELLUNG. 


LDX 

#0 

;SCH ALTER-POSITION NULL 

CHKPOS 

ROR 

A 

IST DAS NÄCHSTE BIT EINE GEERDETE 




; POSITION? 


BCC 

DONE 

;JA. SCHALTERSTELLUNG GEFUNDEN 


INX 


;NEIN, INKREMENTIERE SCHALTER- 




; STELLUNG 


JMP 

CHKPOS 


DONE 

STX 

$40 

;SPEICHERE SCHALTERSTELLUNG 


BRK 
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Objektprogramm: 


Aufgabe 2: Warten auf eine Änderung der Schalterposition 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) 

0000 

A9 

LDA 

#0 

0001 

00 



0002 

8D 

STA 

VIAPCR 

00031 

0004 f 

VIAPCR 



0005 

8D 

STA 

VIAOORA 

000SI 

00071 

VIADtRA 



0008 

AD 

CMKSW LDA 

VIAORA 

00091 

oooaI 

VIAORA 



0008 

C9 

CMP 

#$FF 

oooc 

FF 



000D 

FO 

BEO 

chksw 

000E 

F9 



000F 

A2 

LDX 

tto 

0010 

00 



0011 

6A 

CHKPOS ROR 

A 

0012 

90 

BCC 

DONE 

0013 

04 



0014 

E8 

INX 


0015 

4C 

JMP 

CHKP»S 

0016 

11 



0017 

00 



0018 

86 

DONE STX 

$40 

0019 

40 



001A 

00 

8RK 



Nehmen Sie an, daß ein fehlerhafter Schalter oder ein defekter VIA immer ein 
Ausgangssignal liefern würde, das FF,* ist. Wie könnten Sie dieses Programm 
abandern, so daß es diesen Fehler feststellen würde? 

Dieses Programm konnte leicht anders aufgebaut werden, um es kürzer und 
schneller zu machen - so wie verschiebbar. Eine Option wäre das Ersetzen von 
JMPCHKPOS durch BCS CHKPOS. Weshalb ist dies möglich und welche Ver¬ 
besserungen ergeben sich daraus? Eine weitere Option wäre das Ändern der 
Anfangsbedingungen, so daß nur ein Sprungbefehl erforderlich wäre. Wie wür¬ 
den Sie dies ausführen? Hinweis: Beginnen Sie mit FF,* im Indexregister X und 
mkrementieren Sie X vordem Verschieben des Akkumulators. 


Zweck: Das Programm wartet auf eine Änderung der Schalterposition und pla 
ziert die neue Position (decodiert) in den Speicherplatz 0040. Das Pro 
gramm wartet, bis der Schalter seine neue Lage erreicht 

Flußdiagramm: 



Dieses Beispiel nimmt an, daß der Schalter mittels Hardware entprellt wurde. 
Wie würden Sie dieses Programm ändern, damit die Entprellung durch die Soft¬ 
ware erfolgt? 








Quellprogramm: 


Objektprogramm: 


LDA #0 
STA VIAPCR 

STA VIADDRA 

CHKFST LDA VIAORA 
CMP »$FF 

BEO CHKFST 
TAX 

CHKSEC LDA VIAORA 
CMP # $FF 

BEO CHKSEC 
CPX VIAORA 

BEO CHKSEC 
RORB 

LDX #$FF 
CHKPOS INX 


ROR A 
BCS CHKPOS 
STA $40 
BRK 


MACHE ALLE STEUER-LEITUNGEN ZU 
EINGÄNGEN 

MACHE ALLE PORT-A-LEITUNGEN ZU 
EINGÄNGEN 

BEFINDET SICH DER SCHALTER IN EINER 
POSITION? 

NEIN, WARTE AUF DIE POSITION 

BEWAHRE ALTE POSITION AUF 

BEFINDET SICH DER SCHALTER IN EINER 
POSITION 

NEIN, WARTE AUF POSITION 

IST DIE POSITION DIE GLEICHE WIE 
VORHER 

JA, WARTE AUF EINE ÄNDERUNG 

ST DAS NÄCHSTE BIT EINE GEERDETE 
POSITION? 

NEIN, STARTE SCHALTERSTELLUNG BEI -1 

SCHALTER-POSITION = SCHALTER 
POSITION+1 

LIEGT NÄCHSTES BIT AN MASSE? 

NEIN, HALTE WEITER AUSSCHAU 

SPEICHERE SCHALTERPOSITION 


Speicher-Adresse 

Speicher-Inhall 

(Hex) 

Befehl 

(Mnemonik) 

0000 

A9 

LDA 

#0 

0001 

00 



0002 

BD 

STA 

VIAPCR 

00031 

00041 

VIAPCR 



0006 

BD 

STA 

VIADDRA 

00061 

00071 

VIADDRA 



0008 

AD 

CHKFST LOA 

VIAORA 

00091 

OOOAl 

VIAORA 



0008 

C9 

CMP 

#$FF 

OOOC 

FF 



000D 

FO 

BEQ 

CHKFST 

000E 

F9 



000F 

AA 

TAX 


0010 

AD 

CHKSEC LOA 

VIAORA 

00111 

00121 

VIAORA 



0013 

C9 

CMP 

#$FF 

0014 

FF 



0015 

FO 

BEQ 

CHKSEC 

0016 

F9 



0017 

EC 

CPX 

VIAORA 

0018t 

00191 

VIAORA 



001A 

FO 

BEO 

CHKSEC 

001B 

F4 



001C 

A2 

LDX 

#$FF 

001D 

FF 



001E 

E8 

CHKPOS INX 


001F 

6A 

ROR 

A 

0020 

BO 

BCS 

CHKPOS 

0021 

FC 



0022 

86 

STX 

$40 

0023 

40 



0024 

00 

BRK 



Eine andere Methode zur Bestimmung, ob sich der Schalter in einer Stellung be- 
Imdet ist: 


CHKSW INC VIAORA 

BEO CHKSW 

Wie arbeitet diese? Was geschieht mit den Eingangsdaten? 

Schreiben Sie das Programm zur Verwendung der alternativen Methode, Wieviel 
weniger Speicher ist erforderlich? 
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Eine einzelne LED 

Zweck: Anpassung einer lichl-emittierenden Diode an einen Mikroprozessor 
6502. Die LED kann so angeordnet werden, daß sie entweder durch 
eine Null oder eine Eins eingeschaltet wird. 


Bild 11-19 zeigt die Schaltung, die zum Anschluß einer LED 
erforderlich ist Die LED leuchtet, wenn ihre Anode positiv 
gegenüber ihrer Kathode ist (Bild 11-19 a) Daher kann man 
die LED entweder dadurch zum Leuchten bnngen indem man die Kathode an 
Masse legt, und der Computer eine Ems an die Anode liefert (Bild 11-19 b) oder 
durch Verbinden der Anode mit +5 Volt, wobei der Computer eine Null an die 
Kathode liefert (Bild 11-19 c). Die Steuerung der Kathode ist die am häufigsten 
angewandte Losung Die LED ist am hellsten, wenn sie mit einem gepulsten 
Strom von etwa 10 bis 50 mA gespeist wird, der einige hundertmal pro Sekunde 
zugefuhrt wird. LEDs besitzen eine sehr kurze Einschaltzeit (im Mikrosekunden- 
Bereich), so daß sie sehr gut für Mulliplexen(der Betrieb mehrerer LEDs von 
einem einzelnen Port) geeignet sind. LED-Schallungen benötigen gewöhnlich 
periphere Bausteine oder Transistor Treiber und slrom-begrenzende Widerstän¬ 
de MOS Schaltungen können normalerweise LEDs nicht direkt steuern und sie 
hell genug zum Leuchten bringen. 

Achtung. Der VIA besitzt einen Ausgangs-Zwischenspeicher an jedem Port. Der 
Port B wird jedoch normalerweise für Ausgaben verwendet, da er etwas höhere 
Treibermöglichkeit besitzt. Insbesondere sind die Ausgänge des Ports B in der 
Lage, Darlington-Transistoren anzusteuern (er liefert mindestens 3.0 mA bei 
1.5 V). Darlington-Transisloren sind Transistoren mit sehr hoher Verstärkung, 
die in der Lage sind, große Ströme mit hoher Geschwindigkeit zu schalten. Sie 
sind sehr nützlich bei der Ansleuerung von Spulen, Relais und anderen Baustei¬ 
nen 


LED- 

STEUERUNG 


+5VO 


R 

VW 


a) Grundtegende LED-Schaitung Oer Widerstand aotfte den maximalen Strom 
auf SO mA begrenzen und öen rriltteren Strom aul 10 mA. 


Anode ^^Kaiode 



Ö) Anpassung einer LE Dan positive Logik Eine logisch "1" von der CPU schartet die LED ein 



c) Anpassung »ner LED an negat ive Logik. Ein togiscb X)' von der CPU scnaftet die l£D ein 
Der Treiber oder die CPU können die Logfcpeget umkehren. 


Bild 11-19. Anpassung einer LED. 
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Aufgabe: Ein- und Ausschalten einer LED 

Zweck: Das Programm schaltet eine einzelne LED entweder ein oder aus. 

A. Sende ein logisch 1 zur LED (schalte eine positive Anzeige ein oder eine ne¬ 
gative Anzeige aus). 

Quellprogramm: 

(anfängliches Einstellen der Daten) 


LDA 

#0 


STA 

VIAPCR 

;MACHE ALLE STEUER-LEITUNGEN ZU 
; EINGÄNGEN 

LDA 

#$FF 


STA 

VIADDRB 

;MACHE PORT-B-LEITUNGEN ZU 
AUSGÄNGEN 

LDA 

#MASKP 

;HOLE DATEN FÜR LED 

STA 

BRK 

VIAORB 

;SENDE SIE ZUR LED 


Es wird die B Seite der VIA verwendet, da diese gepullert ist. Die CPU kann des¬ 
halb die Daten vom Ausgangsport lesen 

(Daten aut den neuasten Stand bringen) 

LDA VIAORB .HOLE DIE ALTEN DATEN 

ORA #MASKP ;SCHALTE LED-BIT EIN 

STA VIAORB ;SENDE DATEN ZUR LED 

BRK 

MASKP hat ein 1-Bit in der LED Position und andernfalls Nullen Eine logische 
ODERierung mit MASKP beeinflußt die anderen Bit-Positionen nicht, die Bits für 
andere LEDs enthalten können. Beachten Sie, daß wir die VIA-Ausgangs- 
(Daten)-Register lesen können, auch wenn die Anschlüsse als Ausgänge 
dienen 


Objektprogramm: 


Speicher Adresse 
(Hex) 

Speicher Inhalt 
(Hex) 

Befehl 

(Mnemonik.) 

(Erzeuger der Anfangsdaten) 



0000 

A9 

LDA 

«0 

0001 

00 



0002 

BD 

STA 

VIAPCR 

0003 t 

0004) 

VIAPCR 



0005 

A9 

LDA 

Ä$FF 

0006 

FF 



0007 

BD 

STA 

VIADDRB 

OOOBl 

00091 

ViADDRB 



000A 

A9 

LDA 

tfMASKP 

00IB 

MASKP 



oooc 

8D 

STA 

VIAORB 

OOODi 

000E1 

VlA»RB 



000F 

• • 

BRK 


(Daten auf den neuesten Stand bringen) 



0010 

AD 

LDA 

VIAORB 

001 1 1 

00121 

VIA#RB 



0013 

•9 

• RA 

/fMASKP 

0014 

MASKP 



0015 

8D 

STA 

VIAORB 

00161 

00171 

VIAORB 



0018 

00 

8RK 



B. Sende eine logische Null zur LED (Abschalten einer positiven Anzeige oder 
Einschalten einer negativen Anzeige). 


Die Unterschiede sind, daß MASKP durch sein logisches Komplement MASKN 
und ORA#MASKP durch AND#MASKN ersetzt werden muß. MASKN hat ein 
Null-Bit in der LED-Position und sonst Einsen. Logische UNDierung mit MASKN 
beeinflußt die anderen Bit-Positionen nicht. 
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7-Segment-LED-Anzeige 

Zweck: Anpassung einer 7-Segment-LED-Anzeige an einen Mikroprozessor 
6502. Die Anzeige kann entweder eine gemeinsame Anode (negative 
Logik) oder eine gemeinsame Kathode (positive Logik) besitzen. 

Schaltung: 


Bild 11-20 zeigt die Schaltung, die zur Anpas¬ 
sung einer 7-Segment-LED-Anzeige erforderlich 
ist. Jedes Segment kann ein. zwei oder mehr 
LEDs besitzen, die in der gleichen Weise an¬ 
geordnet sind. Es gibt zwei Möglichkeiten für die Verbindung von LEDs. Bei 
einer Anordnung werden alle Kathoden gemeinsam an Masse geführt (siehe 
Bild 11 -21 a). Dies ist eine Anzeige mil "gemeinsamer Kathode", und eine logi¬ 
sche Eins an einer Anode bnngt dieses Segment zum Leuchten. Bei einer an¬ 
deren Möglichkeit werden alle Anoden gemeinsam an eine positive Betriebs¬ 
spannung geführt (siehe Bild 11-21 b). Dies ist eine Anzeige mit "gemeinsamer 
Anode”, und eine logische Null an einer Kathode läßt dieses Segment leuchten. 
Daher verwendet die Anzeige mit gemeinsamer Kathode positive Logik und die 
Anzeige mit gemeinsamer Anode negative Logik. Jede Anzeige benötigt ent¬ 
sprechende Treiber und Widerstände. 

Die gemeinsame Leitung von der Anzeige wird entweder an Masse 
oder an +5 Volt gelegt Die Anzeige-Segmente werden gewöhnlich fol¬ 
gendermaßen bezeichnet: 


ANZEIGEN MIT GE¬ 
MEINSAMER ANODE 
ODER MIT GEMEIN¬ 
SAMER KATHODE 


<3 


. *> 


9 

r c 


d 

Anmerkung: Die 7-Segment-Anzeige ist weit verbreitet, da sie die kleinste An¬ 
zahl von getrennt gesteuerten Segmenten enthält, die eine gut erkennbare 
Darstellung aller Dezimalzahlen liefert (siehe Bild 11-22 und Tabelle 11-13). 
Mit 7-Segment-Anzeigen kann man auch einige Buschstaben und andere Zei¬ 
chen erzeugen (siehe Tabelle 11-14). Bessere Darstellungen benötigen eine 
wesentlich größere Anzahl von Segmenten und aufwendigere Schaltungen' 6 . 
Da 7-Segment-Anzeigen so populär sind, sind preisgünstige Decoder/Treiber 
für 7-Segment Anzeigen in großem Umfang verfügbar. Der populärste Baustein 
ist der Treiber für gemeinsame Anoden 7447 und der Treiber für gemeinsame 
Kathoden 7448”. Diese Bausteine besitzen Eingänge für Lampen-Tests (mit de¬ 
nen alle Segmente eingeschaltet werden) und Auslast-Eingänge und Ausgänge 
(für das Ausblenden von führenden oder nachstehenden Nullen). 



(Geoiemsan» (Genwisams 

PB, kann Kir eine Deaimalpunkl-LED venMnkieiwenJen Kaltiodef Anodel 


Bild 11-20. Anschluß einerSieben Segment Anzeige. 


Tabelle 11-13. Sieben-Segment Darstellung von Dezimalzahlen. 


Zahl 

Hexadezimale Darstellung 

Gemeinsame Kathode 

Gemeinsame Anode 

0 

3F 

40 

1 

06 

79 

2 

5B 

24 

3 

4F 

30 

4 

66 

19 

5 

6D 

12 

6 

7D 

02 

7 

07 

78 

8 

7F 

00 

9 

67 

18 

Bit 7 ist immer null und die anderen sind g f, e, d, c 
absteigender Reihenfolge der Signifikanz. 

. b und a in 
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11-78 


11-79 









Bild 11-22. Sieben-Segmenl-Darstellung von Dezimalziffern (Fortselzung). 


Tabelle 11-14 Sieben-Segment-Darstellung von Buchstaben und Symbolen. 
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Aufgabe 1: Anzeige einer Dezimalziffer 


Zweck: Zeige an Inhalt des Speicherplatzes 0040 auf einer 7-Segment-Anzeige 
an. wenn er eine Dezimalziffer enthält. Taste andernfalls Anzeige aus. 

Beispiele: 

a (0040) - 05 

Resultat ist 5 auf der Anzeige 

b (0040) - 66 

Das Resultat ist eine dunkel gelastete Anzeige 

FluBdiagramm: 
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Quellprogramm: 


Obrektprogramm: 



LÜA 

#0 



IDA 

VIAPCR 

;MACHE ALLE STEUER-LEITUNGEN ZU 




; EINGÄNGEN 


LDA 

#SFF 



STAA 

VlADDRB 

.MACHE PORT-B-LEITUNGEN ZU 




; AUSGÄNGEN 


LDA 

*BLANK 

;HOLE AUSTAST(BLANK)-CODE 


LDX 

$40 

;HOLE DATEN 


CPX 

#10 

;SIND DATEN 1 0 ODER GRÖSSER? 


BCS 

DSPLY 

;JA, TASTE ANZEIGE DUNKEL 


LDA 

SSEG.X 

;WANDLE DATEN IN 7-SEGMENT-CODE UM 

DSPLY 

STA 

VIAORB 

;SENDE CODE ZUR ANZEIGE 


BRK 



BLANK ist 00 für eine Anzeige mit gemeinsamer Kathode, FF für eine Anzeige 

mit gemeinsamer Anode, Ein 

weiteres Verfahren bestünde darin, den BLANK- 

Code an 

das Ende der Tabelle zu legen und alle ungeeigneten Daten durch 10 

zu ersetzen, d h. 

die Befehle nach STA VlADDRB sind: 


LDX 

#40 

;HOLE DATEN 


CMX 

#10 

;SIND DATEN 10 ODER GRÖSSER? 


BCC 

CNVRT 



LDX 

# 10 

.JA, ERSETZE SIE DURCH 1 0 

CNVRT 

LDA 

SSEG.X 

;WANDLE DATEN IN 7-SEGMENT-CODE UM 


Die Tabelle SSEG ist entweder eine Darstellung der Dazimalzilfern tur die ge¬ 
meinsame Kathode oder gemeinsame Anode aus Tabelle 11-13. 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 


Befehl 

(Mnemonik) 

0000 

A9 


LDA 

AO 

0001 

00 




0002 

8D 


STA 

VIAPCR 

0003 , 

00041 

VIAPCR 




0005 

A9 


LDA 

#$ FF 

0006 

FF 




0007 

80 


STA 

VlADDRB 

00081 

00091 

VIADORB 




000A 

A9 


LDA 

#8LANK 

0008 

BLANK 




oooc 

A6 


LDX 

$40 

000D 

40 




000E 

EO 


CPX 

#10 

000F 

OA 




0010 

BO 


BCS 

DSPLY 

0011 

02 




0012 

B5 


1 DA 

SSEG.X 

0013 

20 




0014 

8D 

DSPLY 

S1 A 

VIAORB 

00151 

00161 

VIA*RB 




0017 

00 


BRK 


0020-0029 


SSEG 

(Sieben Segment- 
Code-Tabelle) 


Mehrere Anzeigen können gemulliple/t werden, wie in Bild 11-23 gezeigt ist Ein 
kurzer Tastimpuls auf der Stuerleitung CB2 taktel den Zähler und leitet die Da¬ 
ten zur nächsten Anzeige RESET startet den Dezimat-Zähler bei 9, so daß die 
erste Ausgabe-Operation den Zahler löscht und die Daten zur ersten Anzeige 
luhrt 

Das tolgende Programm verwendet die Verzogerungs-Routine zum Pulsen |eder 
der zehn Anzeigen mit gemeinsamer Kathode wahrend der Dauer von 1 ms 
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Aufgabe 2: Anzeige von zehn Dezimalziffern 


Objektprogramm: 


Zweck: Zeige den Inhalt der Speicherplätze 0040 bis 0049 aut zehn 7-Segment- 
Anzeigen an, die durch einen Zähler und einen Decodei gemultiplext 
werden. Die höchstweitige Stelle liegt in 0049 

Beispie I: 


(0040) - 

66 

(0041) - 

3F 

(0042) = 

7F 

(0043) = 

7F 

(0044) = 

06 

(0045) = 

5B 

(004«) = 

07 

(0047) = 

4F 

(0048) = 

6D 

(0049) = 

7D 

Die Anzeige liest 6537218804 


Die Schaltung in Bild 11 -23 verwendet das VIA-Ouittierungssignal CB2 als einen 
kurzen Ausgangsimpuls, um das Auftreten eines Datentransfers anzuzeigen. 


Quellprogramm: 



LDA 

#$FF 


STA 

VIADDRB 


LDA 

#%10100000 


STA 

VIAPCR 

SCAN 

LDX 

#10 

DSPLY 

LDA 

S3F.X 


STA 

VIAORB 


JSR 

DEX 

DELAY 


BNE 

DSPLY 


BRA 

SCAN 


;MACHE PORT-B-LEITUNGEN ZU 
; AUSGÄNGEN 

LIEFERE "DATA-READV-IMPULS 
lANZAHL DER ANZEIGEN = 10 
.HOLE DATEN FÜR ANZEIGE 
;SENDE DATEN ZUR ANZEIGE 
;WARTE 1 MS 

;ZÄHLE ANZEIGEN 

;STARTE WEITERE ABTASTUNG 


Das periphere Steuerregister-Bit 7=1, um CB2 zu einem Ausgang zu machen, 
Bit 6 - 1. um einen Impuls zu erzeugen, und Bit 3 = 1, um einen kurzen Tast¬ 
impuls zu erzeugen. Wir haben angenommen, daß das Unterprogramm DELAY 
so modifizieit wurde, daß es ein transparentes Warten von 1 ms liefert. 


Speichei-Adresse 

Speicher-Inhalt 


Befehl 

(Hex) 

(Hex) 


(Mnemonik) 

0000 

A9 


LDA 

#$FF 

0001 

FF 




0002 

8D 


STA 

VIADDRB 

0003) 





0004? 

VIADDRB 




0005 

A9 


LDA 

#%10l00000 

0006 

AO 




0007 

8D 


STA 

VIAPCR 

00081 

0009? 

VIAPCR 




000A 

A2 

SCAN 

LDX 

#10 

000B 

OA 




oooc 

85 

DSPLY 

LDA 

$3F X 

000D 

3F 




OOOE 

8D 


STA 

VIAORB 

000F) 

VIAORB 




00101 




0011 

20 


JSR 

DELAY 

0012 

30 




0013 

00 




0014 

CA 


DEX 


0015 

DO 


BNE 

DSPLY 

0016 

F5 




0017 

FO 


BEQ 

SCAN 

0018 

Fl 
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Bild 11-23 Gemultiplexte Sieben-Segment-Anzeigen 


AUFGABEN 

1) Eine Ein-Aus-Taste 

Zweck: Jedes Schließen der Taste komplementiert (invertiert) alle Bits im 
Speicherplatz 0040. Der Speicherplatz enthalt anfangs null. Das 
Programm sollte die Taste kontinuierlich prüfen und den Speicher¬ 
platz 0040 bei jedem Schließen komplementieren. Man kann auch 
statldessen einen Anzeige-Ausgangsport komplementieren, damit 
die Ergebnisse leichter zu sehen sind. 

Beispiel: 

Der Speicherplatz 0040 enthält anfangs null. 

Das erste Schließen der Taste ändert den Inhalt des Spaicherplalzes 0040 in 

FF 1S , etc. Es werde angenommen, daß die Taste durch Flardware entprellt wird 

Wie konnten Sie Entprellen in Ihr Programm aufnehmen'’ 

2) Entprellen eines Schalters durch Software 

Zweck: Entprellen eines mechanischen Schalters durch Warten, bis zwei 
Lesungen, die eine Entprellzeit voneinander entfernt sind, das glei¬ 
che Ergebnis liefern. Es werde angenommen, daß sich die Ent¬ 
prellzeit (in ms) im Speicherplatz 0040 befindet und die Schalter¬ 
stellung in den Speicherplatz 0041 plaziert wird. 


Beispiel: 

(0040) = 03 oewukt daß das Programm 3 ms zwischen den Lesungen wartet. 

3) Steuerung für einen Drehschalter 

Zweck: Ein weiterar Schalter dient als Ladeschalter für einen nicht codierten 
Drehsonalter mit vier Stellungen. Die CPU wartet, bis der Ladeschaller 
geschlossen (null) ist. und liest dann die Stellung des Drehschalters. 
Dieses Verfahren gestattet dem Operator das Drehen des Drehschal¬ 
ters in seine Endposition, bevor die CPU versucht ihn zu lesen Das 
Programm sollte die Stellung des Drehschalters in den Speicherplatz 
0040 plazieren, Der Ladeschalter ist mit Software zu entprellen. 

Beispiel: 

Bringe Drehschalter in Position 2 Schließe Ladeschalter 
Ergebnis (0042) = 02 
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4) Darstellung der Schalterpositionen auf Lampen 


KOMPLEXERE E/A-BAUSTEINE 


Zweck: Bei einem Satz von acht Schaltern sollte deren Position durch acht 
LEDs dargestellt werden. Das heißt, wenn die Schalter geschlossen 
(null) sind, sollte die LED eingeschaltet sein Andernfalls sollte die LED 
ausgeschaltet sein. Es werde angenommen, daß der Ausgangs-Port 
der CPU mit den Kathoden der LEDs verbunden ist. 

Beispiel: 

SCHALTER 0 GESCHLOSSEN 
SCHALTER 1 OFFEN 
SCHALTER 2 GESCHLOSSEN 
SCHALTER 3 OFFEN 
SCHALTER 4 OFFEN 
SCHALTER 5 GESCHLOSSEN 
SCHALTER 6 GESCHLOSSEN 
SCHALTER 7 OFFEN 

Ergebnis: 


LED 

0 

EIN 

LES 

1 

AUS 

LED 

2 

EIN 

LED 

3 

AUS 

LED 

4 

AUS 

LED 

5 

EIN 

LED 

6 

EIN 

LED 

7 

AUS 


Wie würden Sie das Programm ändern, damit ein Schalter, der mit Bit 7 der Sei¬ 
te A des VIA Nr. 2 verbunden ist, bestimmt, ob die Anzeigen aktiv sind oder 
nicht (d.h., wenn der Steuerschalter geschlossen ist, geben die mit Seite B 
verbundenen Anzeigen den Zustand der mit Seile A verbundenen Schalter 
wieder. Wenn der Steuerschalter offen ist, sind die Anzeigen immer abgeschal¬ 
tet)? Ein Steuerschalter ist nützlich, wenn die Anzeigen den Bedienenden stören 
können, wie etwa in einem Flugzeug, 

Wie würden Sie das Programm ändern, damit der Steuerschalter eine Ein- 
Aus-Taste ist 9 Das heißt, jedes Schließen kehrt den vorhergehenden Zustand 
der Anzeigen um. Es werde angenommen, daß die Anzeigen im aktiven Zu¬ 
stand beginnen und das das Programm die Taste prüft und entprellt, bevor es 
Daten zu den Anzeigen schickt. 

5) Zählung auf einer 7-Segment-Anzeige 

Zweck: Das Programm sollte von 0 bis 9 kontinuierlich auf einer 7-Segment- 
Anzeige zählen, beginnend mit null. 

Hinweis: Versuchen Sie unterschiedliche Längen für die zeitliche Steuerung 
der Anzeigen und beachten Sie, was geschieht. Wann wird die Anzeige sicht¬ 
bar? Was geschieht, wenn die Anzeige während eines Teiles der Zeit ausgeta¬ 
stet wird? 


Komplexere E/A-Bausleine unterscheiden sich von einfachen Tastaturen, Schal¬ 
tern und Anzeigen in lolgendem: 

1) Sie transferieren Daten mit höheren Geschwindigkeiten. 

2) Sie können ihren eigenen internen Takt und eigene zeitliche Steuerung besit¬ 
zen 

3) Sie erzeugen eine Status-Information und benötigen Steuer-Informationen, 
und transferieren Daten 

Infolge ihrer höheren Datenralen muß man diese E/A-Bausleine entsprechend 
handhaben. Wenn der Prozessor nicht den geeigneten Service liefert, kann das 
System Eingangsdaten übersehen oder falsche Ausgangsd@len erzeugen. Man 
arbeitet daher unter wesentlich exakteren Einschränkungen", als dies bei einfa¬ 
chen Bausteinen der Fall ist. Unterbrechungen sind ein bequemes Verfahren für 
die Handhabung von komplexen E/A-Bausteinen, die wir in Kapitel 12 sehen 
werden 

Periphere Geräte wie Tastaturen. Fernschreiber, 

Kassetten und Floppy-Disks erzeugen ihre eige¬ 
ne interne zeitliche Steuerung. Diese Bausteine 
liefern Ströme von Daten, getrennt durch spezielle zeitliche Intervalle. Der 
Computer muß die anfängliche Eingabe- oder Ausgabe-Operation mit dem 
peripheren Takt synchronisieren und dann die entsprechenden Intervalle zwi¬ 
schen aufeinanderfelgenden Operationen liefern. Eine einfache Verzöge¬ 
rungs-Schleife. wie die früher gezeigte, kann die Zeit-Intervalle erzeugen. Die 
Synchronisation kann eine oder mehrere derfolgenden Verfahren benötigen: 

1) Das Ausschau-Hallen nach einem Übergang auf einer Takt- oder Tastlei- 
tung, die vom peripheren Baustein für die zeitliche Steuerung zur Verfü¬ 
gung gestellt wird. Das einfachste Verfahren besteht darin, den Tast¬ 
impuls an eine VIA-Steuerleitung zu führen und auf eine Änderung in dem 
entsprechenden Bit des VIA-Steuerregislers zu warten. 

2) Auffinden der Mitte des Zeit-Intervalles, währenddem die Daten stabil sind. 
Man sollte es vorziehen, den Wert der Daten in der Mitte des Impulses zu be¬ 
stimmen, anstatt an den Flanken, an denen sich die Daten ändern können. 
Das Auffinden der Mitte erfordert eine Verzögerung um die Hälfte eines Über- 
tragungs-lnlervalles (Bit-Zeit) nach der Flanke. Das Abtasten (Sampeln) der 
Daten in der Mitte bedeutet auch, daß kleine zeitliche Fehler nur wenig Ein¬ 
fluß auf die Genauigkeit des Empfanges haben. 

3) Erkennen eines speziellen Startcodes Dies ist leicht, wenn der Code aus ei¬ 
nem einzelnen Bit besieht, oder wenn wir einige zeitliche Informationen be¬ 
sitzen. Das Verfahren ist komplexer, wenn der Code lang ist und zu jeder Zeit 
beginnen könnte. Es wird ein Verschieben erforderlich sein um zu bestim¬ 
men, wo der Sender seine Bits, Zeichen oder Nachrichten startet (dies wird 
auch häufig ein Suchen nach der richtigen "Rahmung"(Framing) genannt. 

4) Wiederholtes Abtasten der Daten. Dies verringert die Wahrscheinlichkeit des 
Empfanges falscher Daten auf verrauschten Leitungen. Eine Majoritäts-Logik 
(wie etwa "best 3 out o! 5" oder "5 out of 8") kann zur Feststellung des tat¬ 
sächlichen Datenwertes verwendet werden. 


SYNCHRONISATION 
MIT E/A-BAUSTEINEN 
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Der Empfang ist natürlich wesentlich schwieriger als das Senden, da die peri¬ 
pheren Geräte den Emplang steuern und der Ccmputer die zeitlichen Informa¬ 
tionen interpretieren muß, die durch den peripheren Baustein erzeugt werden 
Bei der Sendung liefert der Computer die entsprechende zeitliche Steuerung 
und Formatierung für einen speziellen penpheren Baustein, 

Periphere Bausteine können andere Informatio¬ 
nen neben den Daten und der zeitlichen Steue¬ 
rung benöligen oder liefern. Wir bezeichnen die 
anderen Informationen, die vom Computer gesendet werden, als "Steuer- 
Informationen'' Sie können die Art der Operation, Start oder Stop des Vorgang¬ 
es. Taktregister, Freigabe-Pufter wählen, ebenso Formate oder das Ubertra 
gungs Protokoll, Anzeigen für den Operator liefern, Operationen zählen oder die 
Art und die Pnontat einer Operation identifizieren Wir nennen andere Informa¬ 
tionen, die von den penpheren Bausteinen gesendet werden, "Status-Infor¬ 
mationen". Sie können die Art der Operation, die Bereitschaft der Bausteine, 
das Vorhandensein von Fehlerbedingungen, das Format des verwendeten Pro¬ 
tokolls und andere Zustände oder Bedingungen anzeigen. 

Der Computer verarbeitet Steuer- und Status Informationen ebenso wie Daten 
Diese Informationen andern sich selten, obwohl in Wirklichkeit Daten mit hoher 
Geschwindigkeit übertragen werden können. Die Steuer- oder Status-Infor¬ 
mationen können einzelne Bits, Ziflern, Worte oder Mehrfach-Worte sein. Häufig 
werden einzelne Bits und kurze Felder kombiniert und von einem einzelnen Ein¬ 
gangs- und Ausgangsport verarbeitet 

Die Kombination von Status- und Steuer-Informationen in Bytes verringert die 
gesamte Anzahl der E/A-Port-Adressen, die von den peripheren Bausteinen be¬ 
nötigt werden 

Die Kombination bedeutet jedoch, daß individuelle Status-Eingangs-Bits ge¬ 
trennt interpretiert und Steuer-Ausgangs-Bits getrennt bestimmt werden müs¬ 
sen. Die Verfahren für die Trennung der Status-Bits sind folgende: 

Trennung der Status-Bits 


Schritt 1) Lies Status-Daten vom penpheren 
Baustein. 

Schritt 2) UNDiere logisch mit einer Maske (die 
Maske hat Einsen in Bit-Positionen, die 
geprüft werden müssen, andernfalls 
Nullen) 

Schritt 3) Schiebe die getrennten Bits in die niedrigstwertigen Bit-Positionen, 

Schritt 3 ist überflüssig, wenn das Feld aus einem einzelnen Bit besteht, da das 
Null-Flag das Komplement dieses Bits nach dem Schritt 2 enthalten wird (versu¬ 
chen Sie es!). Ein Schiebe- oder Ladebefehl kann Schritt 2 ersetzen, wenn das 
Feld ein einzelnes Bit ist und die niedrigstwertige, höchstwertige oder nächst¬ 
höchstwertige Bit-Position (Positionen 0, 7 oder 6) belegt. Diese Positionen wer¬ 
den oft für die am häufigsten verwendete Status-Information reserviert. Sie soll¬ 
ten versuchen, die erforderlichen Befehls-Sequenzen für den Prozessor 6502 zu 
schreiben. 


TRENNUNG DER 
STATUS¬ 
INFORMATIONEN 


STEUER- UND STATUS¬ 
INFORMATIONEN 


Beachten Sie insbesondere die Verwendung des Befehls Bit-Test. Dieser Befehl 
führt eine logische UND-Operation zwischen dem Inhalt des Akkumulators und 
dem Inhalt eines Speicherplatzes aus. bewahrt jedoch das Ergebnis nicht auf. 
Die Flags werden wie folgt gesetzt: 

Null-Flag - 1. wenn das logische UND ein Null-Resultat erzeugt, 0 wenn es nicht 
der Fall ist. 

Negativ-Flag - Bit 7 des Inhaltes des Speicherplatzes (unabhängig vom Werl 
im Akkumulator). 

Uberlauf-Bit - Bit 6 des Inhaltes des Speicherplatzes (unabhängig vom Wert im 
Akkumulator). 


Setzen und Löschen von Steuer-Bits 

Schritt 1) Lies vorhergehende Steuer-Information 

Schritt 2) UNDiere logisch mit einer Maske, um 

Bits zu löschen (die Maske besitzt Nullen in Bit-Positionen die zu lö¬ 
schen sind, anderswo Einsen). 

Schritt 3) ODERieren logisch mit einer Maske, um die Bits zu setzen (die Mas¬ 
ke besitzt Einsen in Bit-Positionen die zu löschen sind, anderswo 
Nullen). 

Schritt 4) Sende neue Steuer-Information zum peripheren Baustein. 

Hier ist das Verfahren wiederum einfacher, wenn das Feld aus einem einzelnen 

Bit besteht und eine Position an einem von beiden Enden des Wortes belegt. 


KOMBINIEREN VON 
STEUER¬ 
INFORMATIONEN 
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Einige Beispiele für das Trennen und Kombinieren von Status-Bits sind: 


BEISPIELE 

Eine nicht-codierte Tastatur 


1) Ein 3-Bit-Feld in den Bit-Positionen 2 bis 4 des VIA-Ausgangs-(Daten)- 
Registers ist ein Eichfaktor. Plaziere diesen Faktor in den Akkumulator. 


•LIES STATUSDATEN VOM EINGANGSPORT 

LDA VIAOR ;LIES STATUSDATEN 

•MASKIERE UNERWÜNSCHTE BITS WEG UND VERSCHIEBE ERGEBNIS 

AND #%00011100 '.MASKIERE EICHFAKTOR 

LSR A ;VERSCHIEBE ZWEIMAL FÜR NOMINIERUNG 

LSR A 

2) Akkumulator enthält ein 2-Bit-Feld, das in die Bit-Positionen 3 und 4 eines 
VIA-Ausgangs-(Daten)-Registers plaziert werden muß. 

TEMP- $0040 
MASK-%11100111 


BRINGE DATEN ZU FELD-POSITIONEN 

ASL A ;SCHIEBE DATEN ZU BIT-POSITIONEN 3 

; UND4 

ASL A 
ASL A 

AND #%00011000 ;LÖSCHE ANDERE DATENBITS 
STA TEMP 


KOMBINIERE NEUE FELD-POSITIONEN MIT ANDEREN DATEN 


LDA 

VIOADR 


AND 

HMASK 

;LÖSCHE ZU ÄNDERNDES FELD 

ORA 

VIORA 

KOMBINIERE NEUE DATEN MIT ALTEN 

STA 

VIORA 

;GIB KOMBINIERTE DATEN AUS 


Die Dokumentation ist ein ernstes Problem bei 
der Handhabung von Steuer- und Status-Infor¬ 
mationen. Die Bedeutung von Status-Eingaben 
oder Steuer-Ausgaben sind selten offensichtlich. 


DOKUMENTATION DES 
STATUS- UND STEUER¬ 
TRANSFERS 


Der Programmierer sollte den Zweck der Eingabe- und Ausgabe deutlich mit 
Kommentaren wie folgt anzeigen "PRÜFE, WENN LESER EINGESCHALTET 


IST', "WAHLE GERADE PARITAT", oder "AKTIVIERE BITGESCHWINDIG- 
KEITS-ZÄHLER”. Die logischen und Verschiebe-Befehle wären andern¬ 
falls sehr schwierig zu merken, zu verstehen oder fehlerfrei zu machen. 


Zweck: Erkennen des Schließen einer Taste von einer mcht-codierten 3 x 3-Tas- 
tatur und Plazieren der Nummer der Taste, die gedrückt wurde, in den 
Akkumulator 

Tastaturen sind im allgemeinen Anordnungen von Schaltern (siehe Bild 11-24). 
Eine kleine Anzahl von Tasten ist am leichtesten zu handhaben, wenn jede Ta¬ 
ste getrennt mit einem Bit eines Eingangspor;s verbunden wird. Die Anpassung 
der Tastatur ist dann die gleiche, wie die Anpassung eines Satzes von Schal¬ 
tern. 

Tastaturen mit mehr als acht Tasten benötigen 
mehr als einen Eingangsport und daher Multiby¬ 
te-Operationen. Dies ist besondersunrationell, wenn die Tasten logisch ge¬ 
trennt sind, wie in einem Rechner oder einem Terminal, bei denen der Anwender 
nur eine Taste zur gleichen Zeit betätigt. Die Anzahl der erforderlichen Ein¬ 
gangsleitungen kann verringert werden, indem die Tasten in Form einer Matrix 
verbunden werden, wie in Bild 11-25 gezeigt ist Nun stellt jede Taste 
eine Potential-Verbindung zwischen einer Zeile und einer Spalte dar. 
Die Tastatur-Matrix benötigt n x m externe Leitungen, wobei die Anzahl 
der Zeilen und m die Anzahl der Spalten ist. Im Vergleich hierzu benötigt man n 
+ m externe Leitungen, wenn jede Taste getrennt wäre. Die Tabelle 11-15 ver¬ 
gleicht die Anzahl von Tasten, die von typischen Konfigurationen benötigt wer¬ 
den. 

Ein Programm kann bestimmen, welche Taste gedrückt 
wurde, indem sie die externen Leitungen von der Matrix 
verwendet. Das gebräuchliche Verfahren ist eine "Tastatur- 
Abtastung". Wir legen Zeile 0 an Masse und prüfen die Spalten-Leitungen. 
Wenn irgendwelche Leitungen an Masse liegen sind, so wurde eine Taste in die¬ 
ser Zeile betätigt, wodurch eine Verbindung zwischen Zeile und Spalte bewirkt 
wurde. Wir können bestimmen, welche Taste gedrückt wurde, indem wir fest- 
stelten. welche Spalten-Leitung an Masse liegt, d.h., welches Bit des Ein¬ 
gangsports 0 ist. Wenn keine Spalten-Leitung an Masse liegt, so gehen wir zur 
Zeile 1 weiter und wiederholen die Abtastung. Man sieht, daß man feststellen 
kann, ob irgendwelche Tasten gedrückt wurden, indem alle Zeilen gleichzeitig 
an Masse gelegt und die Spalten geprüft werden, 

Die Tastatur Abtastung erfordert, daß die Zeilen-Leitungen zu einem Ausgangs¬ 
port geführt werden und die Spalten-Leitungen zu einem Eingangsport Bild 
11-20 zeigt die Anordnung. Die CPU kann eine spezielle Zeile an Masse legen, 
indem sie eine Null in das entsprechende Bit des Ausgangsports plaziert und 
Einsen in die anderen Bits. Die CPU kann den Zustand der speziellen Spalte be¬ 
stimmen, indem sie das entsprechende Bit des Eingangsports prüft. 

Tabelle 11-15. Vergleich zwischen unabhängigen Verbindungen und 
Matnx-Verbindungen für Tastaturen 


TASTATUR¬ 

ABTASTUNG 


MATRIX-TASTATUR 


Tastatur-Größe 

Anzahl der Leitungen mit un¬ 
abhängigen Verbündungen 

Anzahl der Leitungen mit 
Mat rix-Verbindungen 

3 x 3 

9 

6 

4 « 4 

16 

B 

4x6 

24 

10 

5 » 5 

25 

10 

6x6 

36 

12 

6 x 8 

48 

14 

8 x 8 

64 

16 
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Bild 11 25. Eine Tastatur-Matrix. 
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Bild 11 -26. E/A-Anordnung für eine Tastatur-Abtastung. 
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Aufgabe 1: Bestimmen einer gedrückten Taste 

Zweck: Warten bis eine Taste gedrückt wird. 
Das Verfahren ist folgendes: 


WARTEN AUF EIN 
T ASTEN-SCHLIESSEN 


1) Lege alle Zeilen durch Löschen der Ausgangs-Bits an Masse 

2) Hole die Spalten-Eingaben durch Lesen des Eingangspoils. 

3) Kehre zu Schritt 1 zurück, wenn alle Spatten-Eingaben Einsen sind. 

Flußdiagramm: 



Ouellprogramm: 


LDA 

STA 

LDA 

STA 

STA 

STA 

WAITK LDA 
AND 
CMP 

BEQ 

BRK 


#$FF 

VIADDRB 

#0 

VIAPCR 

VIADDRA 

VIAORB 
VIAORA 
#%000001 11 
#%000001 11 

WAITK 


.MACHE PROT-B-LEITUNGEN ZU 
; AUSGÄNGEN 

.MACHE ALLE STEUER-LEITUNGEN ZU 
: EINGÄNGEN 

MACHE PORT-A-LEITUNGEN ZU 
; EINGÄNGEN 

;LEGE ALLE TASTATUR-ZEILEN AN MASSE 
;HOLE SPALTEN-DATEN DER TASTATUR 
;MASKIERE SPALTEN-BITS 
;LIEGEN IRGENDWELCHE SPALTEN AN 
, MASSE? 

.NEIN, WARTE BIS ES BEI EINER DER FALL 
. IST 
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Aufgabe 2: Identifizieren einer Taste 


Quellpiogramm: 


Zweck: Identifizieren einer Tasten-Betäligung durch Plazieren der Nummer der 
Taste in den Akkumulator. 

Das Verfahren sind folgendermaßen aus: 

1) Setze Tastennummer auf -1. Tastatur-Ausgangsport auf lauter Einsen mit 
Ausnahme einer Null in Bit 0, und den Zeilenzähler auf die Anzahl der Zeilen. 

2) Hole die Spallen-Eingänge durch Lesen des Eingangsports. 

3) Wenn irgendwelche Spalten-Eingänge null sind, gehe zu Schntt 7 weiter 

4) Addiere die Anzahl der Spalten zur Tasten-Nummer, um die nächste Zeile zu 
erreichen 

5) Bnnge den Inhalt des Ausgangsporis durch Verschieben des Null-Bits um 
eine Stelle nach links auf den neuesten Stand. 

6) Dekrementiere Zeilenzähler. Gehe zu Schritt 2. falls irgendwelche Zeilen 
nicht abgetastet wurden, andernfalls gehe zu Schntt 9. 

7) Addiere 1 zur Tastennummer. Verschiebe Spalten-Eingaben um ein Bit nach 
rechts. 

8) Wenn Übertrag - 1, kehre zu Schritt 7 zurück. 

9) Ende des Programms. 

Flußdiagramm: 



FROW 


FCOL 


LDA 

#0 

STA 

VIAPCR 

STA 

VIADDRA 

LDA 

#SFF 

STA 

VIADDRB 

TAX 

LDA 

#%11111110 

sr a 

VIAORB 

LDY 

#3 

LOA 

VIAORA 

AND 

# %000001 11 

CMP 

#%00000111 

BNE 

TXA 

FCOL 

CLC 

ADC 

#3 

TAX 

ASL 

VIAORB 

DEY 

BNE 

BRK 

INX 

FROW 

LSR 

A 

BCS 

BRK 

FCOL 


;MACHE ALLE STEUER-LEITUNGEN ZU EIN¬ 
GÄNGEN 

;MACHE PORT-A-LEITUNGEN ZU 
. EINGÄNGEN 

.MACHE POT-B-LEITUNGEN ZU 
: AUSGANGEN 
;T ASTENNUMMER--1 
;STARTE DURCH LEGEN VON ZEILE 
; NULL AN MASSE 

;ZAHLER IST ANZAHL DERZEILEN 
;HOLE SPALTEN-EINGANG B 
;ISOLIERE SPALTEN-BITS 
;LIEGEN IRGENDWELCHE SPALTEN AN 
; MASSE? 

;JA, BESTIMME WELCHE 

;NEIN. BRINGE TASTENNUMMER ZUR 

; NÄCHSTEN ZEILE 

;DURCH ADDIEREN DER ANZAHL DER 
; SPALTEN 

;BRINGE ABTAST-MUSTER FÜR NÄCHSTE 
; ZEILE AUF DEN NEUESTEN STAND 
;WURDEN ALLE ZEILEN ABGETASTET? 

;NEIN, TASTE NÄCHSTE AB 

TASTENNUMMER = TASTENNUMMER +1 
IST DIES DIE AN MASSE LIEGENDE 
SPALTE? 

NEIN,PRÜFE NÄCHSTE 
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Objektprogramm: 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 


Befehl 

(Mnemonik) 

(XXX) 

A9 


LOA 

#0 

OOOl 

00 




0002 

8D 


STA 

VIAPCR 

0003 t 

00041 

VIAPCR 


LD 

A00001111B 

0005 

8D 


STA 

VIADDRA 

0006) 

000 7 f 

VIADDRA 




0008 

A9 


LDA 

#$FF 

0009 

FF 




000A 

BD 


STA 

ViADDRÖ 

000BI 

ooocf 

VIADDRB 




000D 

AA 


TAX 


000E 

A9 


LDA 

>*%11111110 

000F 

FE 




0010 

8D 


STA 

VIAORB 

00111 

0012» 

VIAORB 




0013 

AO 


LD? 

#3 

0014 

03 




0015 

AD 

FROW 

LDA 

VIA»RA 

00161 

0017) 

VIAORA 




0018 

29 


AND 

#%00000l11 

0019 

07 




001A 

C9 


CMP 

#%00000l 11 

0018 

07 




001C 

DO 


BNE 

FCOL 

001D 

OC 




001E 

BA 


TXA 


OOlF 

18 


CLC 


0020 

69 


ADC 

#3 

0021 

03 




0022 

AA 


TAX 


0023 

OE 


ASL 

VlA»RB 

00241 

0025) 

VIAOR8 




0026 

88 


DEY 


0027 

DO 


BNE 

FROW 

0028 

EC 




0029 

00 


BRK 


002A 

E8 

FCDL 

INX 


0028 

4A 


LSR 

A 

002C 

80 


BCS 

FCOL 

0020 

FC 




002E 

00 


BRK 



W| r haben eine CLC-Befehl für zusätzliche Deutlichkeit einqefüat er ist ierinnh 
nicht wirklich erforderlich. Der einzige Fall, in dem der BNE-Befehl kelne^w 

den J nii?rh bew l k | t ' h' derie "' 9e ’ bei dem die zwei im CMP vei wendeten Ope^an- 
den gleich sind. In diesem Falt wird das Ubertrags-Flag immer qesetzt um anzn 
zeigen, daß kein 'Borgen" erzeugt wurde. So könnlen wir die Sequenz 


CLC 

ADC #3 


iDURCH ADDIEREN DER ANZAHL DER 
; SPALTEN 


Durch den Einzelbefehl 


ADC #2 


;DURCH ADDIEREN DER ANZAHL DER 
, SPALTEN (BEACHTE ÜBERTRAG = 1) 


ersetzen. 


z e/ en - Ab t a stung ke.nen Erfolg hat. müssen wir die Anzahl 
f , a len zur Tasten-Nummer addieren, um so über die momentane Zeile hin¬ 
auszukommen (versuchen Sie das Verfahren an der Tastatur in Bild 1 1 -26) 

Andorn’ q 3S . Ergabnis des Programmes, wenn keine Tasten gedrückt wurden? 
Wartet «frd wir , P ( !’ 09 t ramm sa daß die Abtastung in diesem Fall neuerlich ge- 
1 d W k ° nnten elnen zusätzlichen INX-Befehl vor dem ersten BRK ein- 
fugen. Was wäre der endgültige Wert i m Indexregister X wenn keine Tasten ce 
druckt werden? Wäre es anders als der Fall, in dem die höchs.numerStSe 
Pe e S d ve?wend^ Bea 5 h,e " Sle ; daß das Nullflag auch zum Unterscheiden des Fal- 
Sie SSS ' k “' Tasteri 9 ed f ückl werden. Können 

tahren A Häre a,iVe beSteh ' ^ der bidirektlonalen Möglichkeit des VIA. Das Ver- 


1) Lege alle Spalten an Masse und bewahre die Zeilen-Eingänge auf. 

2) Lege alle Zeilen an Masse und bewahre Spalten-Eingänge auf. 

3) Verwende die Zeilen- und Spalten-Eingänge zusammen, um die Tasten- 
Nummer aus einer Tabelle zu bestimmen. 

Versuchen Sie ein Programm zur Ausführung dieses Verfahrens zu schreiben. 

Das Programm kann verallgemeinert werden, indem die Nummern der Zeilen, 
die Nummern der Spalten und die Maskier-Muster in Parameter mif Namen mit 
EOUATE (=)-Pseudo-Operationen verwandelt werden. 
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Eine codierte Tastatur 16 


Zweck: Hole die Daten,wenn sie von einer codierten Tastatur verfügbar sind, die 
einen Impuls zusammen mit jedem Daten-Transfer liefert. 

Eine codierte Tastatur liefert einen eindeutigen Code für jede Taste. Sie besitzt 
interne Elektronik, die die Abtastung und Identifizierung des vorhergehenden 
Beispiels ausführt. Man hat die Wahl zwischen der einfacheren Software, die 
von der codierten Tastatur benötigt wird und den niedrigeren Hardware-Kosten 
der nicht codierten Tastatur, 


Codierte Tastaturen können Dioden-Matnzen verwenden. VTL-Codierer oder 
MOS-Codierer. Die Codes können ASCII. EBCDIC oder ein sonstiger Code sein. 
Die Codierschaltungen enthalten häufig PROMs. 


ROLLOVER 


Die Codierschaltung kann mehr ausführen, als nur das 
Schließen der Tasten codieren Sie kann auch die Tasten 
entprellen und das "Rollover". das Problem der Betätigung von mehreren Ta¬ 
sten zur gleichen Zeit, verarbeiten. Bekannte Verfahren für die Handhabung des 
Rollover beinhalten das "2-Key-Rollover", wobei zwei Tastenbestätigungen (je¬ 
doch nicht mehr) zur gleichen Zeit in getrennte Betätigungen aufgelöst werden, 
sowie das "n-Key-Rollover", wobei jede Anzahl von Tastenbetätigungen zur 
gleichen Zeit in getrenntes Schließen der Tasten aufgelöst wird. 


Eine codierte Tastatur liefert auch einen Impuls mit jedem Datentransfer. Dieser 
Impuls signalisiert ein neues Schließen einer Taste Bild 11-27 zeigt das Interfa¬ 
ce zwischen einer codierten Tastatur und dem Mikroprozessor 6502 


0alenbu$ 

lurCPU 



Bild 11-27. E/A-Interface für eine codierte Tastatur 


Aufgabe: Eingabe von Tastatur 

Zweck: Warte auf einen Impuls mit aktiv Low vom VIA auf der Steuerleitung 
CA1 und plaziere dann die Daten vom Port A in den Akkumulator. 
Beachten Sie, daß das Lesen der Daten vom Ausgangs-(Daten)Register 
das Status-Bit im Unterbrechungsflag Register löscht (diese Schaltung 
ist Teil des VIA 6522). 

Flußdiagramm: 


Der Versatile Interface-Adapter 6522 ermöglicht einen Eingangs Zwischen¬ 
speicher an beiden Ports A und B. Diese Zwischenspeicher werden durch Set¬ 
zen von Bit 1 (für Port B) oder Bit 0 (für Port A) oder des Hilfs-Steuerregisters 
(siehe Bild 11-10) freigegeben. In dieser Betriebsart werden die Daten an den 
Eingangs-Anschlüssen zwischengespeichert, wenn das Unterbrechungsflag ge¬ 
setzt ist und werden sich nicht ändern, bis das Unterbrechungsllag gelöscht 
wird. Beachten Sie, daß die Zwischenspeicher etwas anders als die auf der B- 
Seite arbeiten, bei denen der Inhalt der Ausgangsregister zwischengespeichert 
wird, wenn der Anschluß als Ausgang programmiert ist. 

Der Tastatur-Tashmpuls wird zum Eingang CA1 gefühlt. Ein Übergang an der 
Tastleitung bewirkt, daß das Unterbrechungsflag-Registerbit 1 auf High geht. 
Bit 0 des peripheren Steuerregisters (siehe Bild 11-9) bestimmt, ob der VIA 
High-auf-Low-Ubergänge an CA1 (Bit 0-0) oder Low auf-High-Übergange (Bit 
0=1) erkennt. 

Der VIA enthält einen seriellen, flanken-emplindlichen zwischengespeicherten 
Statusport, sowie einen Datenport. Er enthält ferner einen Inverter, der zur 
Handhabung von Impulsen jeder Polantät verwendet werden kann. Der VIA 
kann mehrere einfache Schalterelemente ersetzen. Der Entwickler kann Korrek¬ 
turen durchführen, indem er den Inhalt des Steuer-Registers (in Sottware) än¬ 
dert, bevor er einen Aufbau neu entwirft. Zum Beispiel benötigt die Änderung 
der aktiven Flanke nur die Änderung eines einzelnen Programm-Bits, während 
es andernfalls zusätzliche Schalt-Elemente und eine neue Verdrahtung erfor¬ 
dern würde. 



Die Hardware muß die Steuerleitung in einem logischen 'T'-Zustand während 
des Resets halten, um zu verhindern, daß die Status Fiags zufällig gesetzt wer¬ 
den. Ein anfängliches Lesen des Daten-(Ausgangs JRegisters in der Start-Rou- 
line kann zum Löschen der Status-Fiags verwendet werden. Wie bereits früher 
erwähnt, können Sie auch die Bits im Ünterbrechungs-Flag-Register des 6522 
durch Einschreiben von Einsen löschen. 
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Ouellprogramm: 


LDA 

STA 

STA 

LDA 

STA 

LDA 

KBWAIT BIT 
BPO 
LDA 
BRK 


#0 

VIAPCR 

VIADDRA 

#%00000001 

VIAACR 

#%00000010 

VIAIFR 

KBWAIT 

VIAORA 


.MACHE ALLE STEUERLEITUNGEN ZU 
: EINGÄNGEN 

■MACHE PORT-A-LEITUNGEN ZU 
; EINGÄNGEN 

.GIB ZWISCHENSPEICHER AN PORT A FREI 
;MACHE MUSTER FÜR PRÜFUNG DES CA1 - 
; FLAGS 

.LIEGEN NEUE TASTATUR DATEN VOR? 
.NEIN. WARTE BIS DIES DER FALL IST 
;JA, HOLE DATEN 


Objektprogramm: 


Speicher-Adresse 

(Heu) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) 

0000 

A9 

LDA 

#0 

0001 

00 



0002 

8D 

STA 

VIAPCR 

00031 

VIAPCR 



00041 




0005 

8D 

STA 

VIADDRA 

0006} 

VIADDRA 



00071 




0008 

A9 

LDA 

#%00000001 

0009 

01 



000A 

8D 

STA 

VIAACR 

0008} 

VIAACR 



ooocl 




000D 

A9 

LDA 

#%00000010 

000E 

02 



000F 

2C 

K8WAIT BIT 

VIAIFR 

OOIOI 

VIAIFR 



0011t 




0012 

F0 

eso 

KBWAIT 

0013 

FB 



0014 

AD 

LDA 

VIAORA 

0015} 

VIADRA 



00161 




0017 

00 

BRK 



Um zu veranlassen, daß das Status-Brl auf einen Low auf High-Übergang aul 
CA1 reagiert, müssen Sie Bit 0 des Unterbrechungs-Fiag-Registers setzen. 

Die anderen Ouittierungs-Statusflags sind Bit 0 (für CA2), 3 (für CB2) und 4 (für 
CB1) des Unterbrechungsflag-Registers. 


Beachten Sie, daß entweder das Lesen oder Schreiben des Ausgangs-(Daten)- 
Registers das Statusbit löscht. Was geschieht, wenn Sie Port A von der Adresse 
ohne Quittierung lesen (Tabelle 11-7)? Was geschieht, wenn Sie LDA VIAORA 
durch LDA VIAORB ersetzen? 


Ein Digital-Analog-Wandler 19 " 22 

Zweck: Sende Daten zu einem 8-Bit-Digitai-Analog-Wandler, der eine Zwischen¬ 
speicher-Freigabe mit aktiv-Low besitzt. 

Digital-Analog-Wandler erzeugen ein kontinuierliches Signal, das von Motoren. 
Heizwicklungen. Relais und anderen elektrischen und mechanischen Ausgangs- 
Bausteinen benötigt wird. Typische Wandler bestehen aus Schaltern und Wider¬ 
stands-Ketten mit den entsprechenden Widerstands Werten, in der Regel muß 
man eine Referenz Spannung vorsehen, sowie weitere digitale und analoge 
Schaltungen, obwohl vollständige Einheiten nunmehr preisgünstig zur Verfü¬ 
gung stehen. 

Bild 11-28 beschreibt den 8-Bit-D/A Wandler Signetics NE5018, der auf dem 
Chip einen parallelen Dateneingangs-Zwischenspeicher mit 8 Bits enthält. Ein 
niedriger Pegel auf dem LE-Eingang (Latch Enable) taktet die Eingangsdaten in 
den Zwischenspeicher, wo sie verbleiben, nachdem LE wieder auf High gegan¬ 
gen ist. 


Bild 11-29 zeigt die Anpassung des Bausteins an 
ein 6502-System. Beachten Sie, daß die B-Seite 
des VIA automatisch einen Impuls mit aktiv Low erzeugt, der zum Einspeichern 
der Daten in den Wandler erforderlich ist. CB2 dient als ein Signal für "Ausgang 
Bereit" (Output Ready). Erinnern Sie sich daran, daß CB2 automatisch für die 
Dauer eines Zyklus auf Low geht, nach einer Schreib Operation beim Datenregi¬ 
ster am B-Port des Ausgangs-(Daten)-Registers, wenn CB2 in der Impuls-Aus- 
gangs-Betriebsart ist, (siehe Tabelle 11-59). Die peripheren Steuerregister-Bits 
sind: 


D/A-WANDLER 

INTERFACE 


Bit 7 - 1. um CB2 zu einem Ausgang zu machen 
Bit 6 - 0, um CB2 zu einem Impuls zu machen 

Bit 5 - 1, um CB2 zu einem kurzen "Output Ready"-Impuls zu machen (für 
die Dauer eines Takt-Zyklus). 

Beachten Sie, daß der VIA einen Ausgabe-Zwischenspeicher enthält. Die Daten 
bleiben daher während und nach der Umwandlung stabil. Der Wandler benötigt 
typisch einige wenige Mikrosekunden, um ein analoges Ausgangssignal zu er¬ 
zeugen. Daher kann der Zwischenspeicher des Wandlers freigegeben bleiben, 
wenn der Port nicht für andere Zwecke verwendet wird. 

in Anwendungen, in denen 8 Bit Auflösung nicht ausreichen, können 10- bis 
16-Bit-Wandler verwendet werden. Eine zusätzliche Port-Logik ist erforderlich, 
um alle Datenbits zu verarbeiten. Einige Wandler liefern einen Teil dieser Logik. 


Zeigen Sie, daß das Lesen des Ausgangs-(Daten)-Registers das Status-Bit 
löscht. Hinweis: Retten Sie den Inhalt des Unterbrechungs-Fiag-Registers in den 
Speicher, bevor der Befehl LDA VIAORA ausgeführt wird. Was geschieht, wenn 
man LDA durch STA ersetzt? Wie ist es mit CMP. INC, ROL? 


Der VIA dient sowohl als paralleler Daten-Port, wie auch als Steuerport, CB2 
ist ein Impuls, der einen Takt-Zyklus nach dem Einspeichern der Daten in den 
VIA dauert. Dieser Impuls ist lang genug, um die Erfordernisse des Konverters 
NE5018 zu erfüllen (typisch 400 ns). 
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11-106 


Alle R-Werte betregen 5kO uoö'Sind thermisch ausgesuchi 
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Aufgabe: Ausgabe zum Konverter 

Zweck: Sende Daten vom Speicherplatz 0040 zum Wandler. 

Flußdiagramm: 


( ” ) 


Daten 

(0040) 


i 

Seortp Daten rum 
Wandler und 
speichere sie 




( E L ) 


Quellprogramm: 


LDA 

#$FF 


STA 

VIADDRB 

.MACHE PORT-B-LEITUNGEN ZU 
: AUSGÄNGEN 

LDA 

#% 10100000 


STA 

VIAPCR 

;LIEFERE KURZEN 

1 ZWISCHENSPEICHER-FREIGABE-IMPULS 

LDA 

$40 

;HOLE DATEN 

STA 

BRK 

VIAORB 

.SENDE DATEN ZUM DA-WANDLER UND 
; ZWISCHENSPEICHER 


Objektprogramm: 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) 

0000 

A9 

LDA 

#$FF 

0001 

FF 



0002 

8D 

STA 

VIADDRB 

00031 

VIADDRB 



00041 




0005 

A9 

LDA 

#%10100000 

0006 

AO 



0007 

8D 

STA 

VIAPCR 

00081 

VIAPCR 



C009' 




OOOA 

A5 

LDA 

$40 

000B 

40 



oooc 

BD 

STA 

VIAORB 

000D( 

VIAORB 



000EI 




000F 

00 

BRK 



Der Impuls für den Zwischenspeicher-Freigabe-Eingang wird automatisch er¬ 
zeugt, wenn Daten in das Ausgangs (Daten) Register B gespeichert werden. 
Beachten Sie, daß der Impuls ziemlich kurz ist und nur einen Taktzyklus dauert 
Dies könnte für einige Anwendungen nicht ausreichen. 

Wir könnten den (manuellen) Pegel Ausgang von CB2 verwenden, wem das 
Zwischenspeicher-Freigabesignal aktiv High wäre, oder wenn die erforderliche 
Länge größer wäre. Das Programm würde dann folgendermaßen aussehen: 


LDA 

#$FF 


STA 

VIADDRB 

;MACHE PORT-B-LEITUNGEN ZU 

LDA 

#%11000000 

AUSGÄNGEN 

STA 

VIAPCR 

;MACHE ZWISCHENSPEICHER-FREIGABE 

LDA 

$40 

; ZU EINEM PEGEL (LOW) 

;HOLE DATEN 

STA 

VIAORB 

;SENDE DATEN ZUM 

LDA 

#%11100000 

; DA-WANDLER-AUSGANGSPORT 

STA 

VIAPCR 

;ÖFFNE DA-WANDLER-ZWISCHENSPEICHER 

LDA 

#% 11000000 

: (FREIGABE HIGH) 

STA 

VIAPCR 

;SPEICHERE DATEN (FREIGABE LOW) 

BRK 




Hier wird Bit 6 des peripheren Steuerregisters gesetzt, um CB2 zu einem Pegel 
zu machen, mit einem Wert, der durch Bit 5 des peripheren Steuerregisters ge¬ 
geben ist. Dies wird als die "manuelle' 1 Ausgangs-Betriebsart in der Literatur 
des 6522 bezeichnet. Beachten Sie, wieviel mehr Befehle erforderlich sind, um 
die Zwischenspeicher Freigabe (Latch Enable) wie im vorhergehenden Beispiel 
zu pulsen, da kein automatischer Impuls geliefert wird. Ein invertierendes Gat¬ 
ter könnte auch zum Invertieren der Polarität des Tastimpulses verwendet 
werden. 

In der manuellen Betriebsart ist CB2 vollständig unabhängig vom parallelen Da¬ 
tenport Er ist einfach ein Steuerausgang, der für jeden Zweck verfügbar ist. Das 
einzige Problem bei der Verwendung besteht darin, daß Sie nicht zufällig Irgen¬ 
deines der anderen Bits im peripheren Steuerregister ändern dürfen, da Sie 
sonst unkontrollierte Funktionen erzeugen. 
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Analog-Digital-Wandler 19 ' 23 

Zweck: Hole Daten von einem Analog-Digital-Wandler mit 8 Bits der einen Im¬ 
puls "Starte Umwandlung" (Start Conversion) benötigt, um den Um¬ 
wandlungsprozess in Gang zu setzen und eine Leitung "End of Conver¬ 
sion" (Ende der Umwandlung) besitzt um den Abschluß des Vorganges 
anzuzeigen, sowie die Verfügbarkeit gültiger Daten 

Analog-Digital-Wandler verarbeiten das kontinuierliche Signal, das von ver¬ 
schiedenen Arten von Sensoren und Wandlern erzeugt wird. Der Wandler er¬ 
zeugt das digitale Ausgangssignal, das vom Computer benötigt wird. 

Eine Form eines Analog-Digitai-Wandlers ist der Baustein für die sukzessive Ap¬ 
proximation, der einen direkten 1-Bit-Vergleich während jedes Takt-Zyklus aus¬ 
führt. Derartige Wandler sind schnell, besitzen jedoch eine geringe Rausch- 
Unempfindlichkeit. Die integrierenden Duai-Siope-Konverter sind eine weitere 
Art der Analog-Digital-Wandler. Diese Bausteine benötigen mehr Zeit, sind je¬ 
doch nicht so empfindlich gegen Rauschen. Es werden auch andere Verfahren, 
wie etwa die schrittweise Ladungs-Kompensation verwendet. 

Analog-Digital-Wandler benötigen gewöhnlich einige externe, analoge und digi¬ 
tale Schaltungen. Vollständige Einheiten sind nach und nach preisgünstiger er¬ 
hältlich 

Bild 11-30 zeigt den A/D-Wandler mit 8 Bits MM5357 von National Der Baustein 
erhält einen Zwischenspeicher für das Ausgangssignal und Tristate-Datenaus- 
gänge Ein Impuls auf der Leitung "Start Conversion" (STRT CONV) startet die 
Umwandlung des Analog-Einganges. 

Nach etwa 40 Taktzyklen (der Wandler benötigt einen Takt mit TTL-Pegel mit ei¬ 
ner Mindestimpulsbreite von 400 ns), wird das Ergebnis zu den Ausgangs- 
Zwischenspeicher gelangen und der Ausgang "End of Conversion" (EOC) wird 
dies anzeigen, indem er auf High geht. Daten werden von den Zwischenspei¬ 
chern gelesen, indem eine 1 zum Eingang "Ausgangs-Freigabe" geführt wird 
Bild 11-31 ziegt die Verbindung für den Baustein und einige typische Anwender¬ 
schaltungen. 

Bild 11-32 zeigt das Interface für den Prozessor 
6502 und den A/D-Wandler 5357. Die Steuerlei¬ 
tung CA2 wird in der manuellen (Pegei)-Aus- 
gabe-Betriebsait verwendet, um einen Impuls "Start Conversion" (aktiv-High) 
ausreichender Länge zu liefern. Das Signal "End of Conversion" wird zur Steuer¬ 
leitung CA1 geführt, so daß, wenn EOC auf High geht, das Bit 1 des Unterbre¬ 
chungsflag-Registers gesetzt wird. Die wichtige Flanke auf der Leitung "End of 
Conversion" ist die Flanke Low-auf-High, die den Abschluß der Umwandlung an¬ 
zeigt. Beachten Sie, daß wir bei der Verwendung des Bausteins 6522 sowohl 
den Steuereingang als auch den Steuerausgang handhaben, da das Wandler- 
Interface eine vollständige Quittierung beinhaltet. Der Anschluß "Output Enable" 
am Konverter wird auf High gelegt, da wir die Daten nicht direkt auf den Tristate- 
Datenbus des Prozessors plazieren. Beachten Sie (siehe Bild 11-30), daß die 
Datenausgänge des Konverters komplementierte Binärwerte sind (alles Nullen 
sind Vollauschlag). 


A/D-WANDLER¬ 

INTERFACE 


NATIONAL 

MM 5357 B-6U-A/D-Wandler 


Allgemeine Beschreibung 


Der MM5357 ist ein monolithischer B-Bit-A/O-Wandler, der in lonen-imptantierter P-Kanai-MoS- 
Technologie geleiligi wird. Er enthält einen Komparator mit hoher Eingangs-Impedanz, 256 Serien- 
Widerstände und Analog-Schalter. Steuer-Logik und Ausgangs-Zwischenspeicher Die Umwandlung 
basiert auf dem Verfahren der sukzessiven Approximation, bei dem die unbekannle Analog-Span¬ 
nung mit den Verbindungspunkten der Widerslände unter Verwendung von Analog-Schaltern ver¬ 
glichen wird Wenn die Spannung am entsprechenden Verbindungspunkt mit der unbekannten Span¬ 
nung übereinstimmt, ist die Umwandlung abgeschlossen und die digitalen Ausgänge enthalten ein 
komplementäres t-8it-Wort, das der unbekannten Spannung entspricht. Die Bmär-Ausgange sind 
Tristale-Ausgänge, wodurch eine Verbindung mit gemeinsamen Daten-Leilungen möglich ist. 

Eigenschaften: 

■ Niedrige Kosten 

■ Eingangs-Bereiche + 5 V, 10 V 

■ Hohe Eingangs-Impedenz 

■ Trislate-Ausgänge 

■ Enthält Ausgangs-Zwischenspeicher 

■ Ti'L-kompatibel 


Wichtigste Spezifikationen 

■ Auflösung 

■ Linearität 

■ Umwandlungs-Geschwindigkeit 
• Eingangs-Impedanz 

■ Betriebs-Spannungen 

■ Takt-Bereich 


BBits 

-1/2LSB 

40MS 

> 100MG 
+ 5V.-12 V, Masse 
5.0 kHz bis 2.0 MHz 


Zeitlicher Ablauf: 


Takt- 

Eingang 


0 V 


7W\AAAAAJVLT\J 


Start +5 V 
der Um¬ 
wandlung 0 V 


EOC 


Ausgangs- 

Freigabe 


♦5 V 
0 V 
♦ 5 V 
0 V 


m 


-tt- 


-40 X<1 fl- 

—#- 


d 


^ V iTci-statel 


-W- 


0 V ■ 


X 


Freigabe - 

Verzögerung 


Sperr- _ 
Verzögerung 


Die Daten liegen in komplementär Binär vor (Vollausschlag = 0000§000). 


Bild 11-30. Allgemeine Beschreibung und Arbeitsweise des A/D-Wandlers 

National 5357 
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Bild 11-32. Interface für einen 8-Bit-Analog/Digitai-Wandler. 


1 1-112 


Aufgabe: Eingabe vom Wandler 


Zweck: Starte den Umwandlungsprozess, warte auf "End of Conversion", das 
auf Low und dann auf High geht, lies dann die Daten und speichere sie 
in den Speicherplatz 0040. 

Flußdiagramm: 



Beachten Sie, daß hier der VIA als ein paralleler Datenporl, als Status-Port und 
als Sleuer-P»rt dient. 

Quellprogramm: 
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Objektprogramm: 


Ein Fernschreiber (TTY = Teletypewriter) 


Speicher-Adresse 

Speicher-Inhalt 

Befehl 

(Hex) 

(Hex) 

(Mnemonik) 

0000 

A9 

LDA 

#0 

0001 

00 



0002 

8D 

STA 

VIADDRA 

0003 ( 

00041 

VIADDRA 



0005 

A9 

LDA 

#%00001101 

0006 

OD 



0007 

8D 

STA 

VIAPCR 

0008i 

00091 

VIAPCR 



0*0A 

A9 

LDA 

#94000 01111 

000B 

OF 



OOOC 

8D 

STA 

VIAPCR 

OOODI 

000E1 

VIAPCR 



000F 

A9 

LDA 

#%00001101 

0010 

OD 



0011 

8D 

STA 

VIAPCR 

0012» 

VIAPCR 



0013( 



0014 

AO 

WTEOC LDA 

V1AIFR 

0015t 

00161 

VI AI FR 



0017 

29 

ANO 

#%00000010 

0018 

02 



0019 

DO 

BNE 

WTEOC 

001A 

F9 



OOlß 

AD 

LOA 

VlAORA 

ooict 

0011D1 

VlAORA 



0 01E 

49 

6DR 

#9411 111111 

0 01F 

FF 



0020 

85 

STA 

$40 

0021 

40 



0022 

00 

BRK 



Die VIA-Steuerregister-Bits sind: 

Bit 3 - 1, um CA2 zu einem Ausgang zu machen 

Bit 2 - 1. um CA2 zu einem Pegel zu machen (Manuelle Ausgabe- 
Betriebsart) 

Bit 1 - Wert des Pegels an CA2 

Bit 0 - 1. um das Status-Fiag bei einem Low-auf-High-übergang auf CA1 
zu setzen 

Beachten Sie, daß VIAs unter Verwendung der nach-indizierten Adressierung 
adressiert werden könne. Die Start-Adresse des VIA (VIAORB) wird in zwei 
Speicherplätzen auf Seite Null plaziert. Alle VIA-Register können mit entspre¬ 
chenden Versetzungen im Indexregister Y erreicht werden 


Zweck: Transferiere Daten zu und von einem seriellen 
Standard-Fernschreiber mit 10 Zeichen pro Sekun¬ 
de 


TTY- 

INTERFACE 


Im allgemeinen transferieren Fernschreiber Daten in einem asynchronen seriel¬ 
len Bertrieb Das Verfahren ist folgendes 


1) Die Leitung ist normalerweise im Ein-Zustand 


2) Ein Start-Bit (Null-Bit) geht jedem Zeichen vor¬ 
aus. 


STANDARD-T7V 

ZEICHENFORMAT 


3) Das Zeichen liegt gewöhnlich im 7-Bit ASCII vor, wobei das niedrigstwertige 
Bit zuerst gesendet wird, 

4) Das höchstwertige Bit ist ein Paritäts-Bit, das gerade, ungerade oder fest auf 
Eins oder Null liegen kann. 

5) Zwei Stop-Bits (logisch Eins) folgen jedem Zeichen, 

Bild 11-33 zeigt das Format. Beachten Sie, daß jedes Zeichen die Übertragung 
von elf Bits erfordert, von denen nur sieben Informationen enthalten. Da die Da- 
ten-Geschwindigkeit 10 Zeichen pro Sekunde beträgt, ist die Bit-Rate gleich 
10x11 oder 110 Baud. Jedes Bit besitzt daher eine Breite von i/i 10 einer Se¬ 
kunde, oder 9.1 Millisekunden. Diese Breite ist ein Durchschnitt. Die Fernschrei¬ 
ber übertragen nicht mit beliebigerhoher Genauigkeit. 
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Damit ein Fernschreiber ordnungsgemäß mit einem Computer kommuniziert, 
sind folgende Verfahren erforderlich: 

Empfang (Flußdiagramm in Bild 11-34): 


Schritt 1) Halte nach einem Start-Bit (einer logi¬ 
schen Null) auf der Datenleitung Aus¬ 
schau. 

Schritt 2) Zentriere den Empfang durch Warten für die Dauer eines halben Bits, 
oder 4,25 Millisekunden, 

Schritt 3) Hole die Datenbits, wobei für die Zeit eines Bits für jedes einzelne ge¬ 
wartet wird. Fasse die Datenbits in ein Wort zusammen, indem zuerst 
das Bit zum Übertrag geschoben wird und dann die Daten mit dem 
Übertrag zirkular verschoben werden. Ennnern Sie sich daran, daß 
das niedrigstwertige Bit zuerst empfangen wird, 

Schrift 4) Erzeugen Sie die empfangene Parität und prüfen Sie diese gegenü¬ 
ber der gesendeten Parität, Wenn keine Übereinstimmung vorhanden 
ist, zeige einen "Paritätsfehler" an, 

Schritt 5) Hole die Stop-Bits (warten für die Zeit eines Bits zwischen den Eingän¬ 
gen). Wenn sie nicht korrekt sind (wenn beide Stop-Bits nicht Eins 
sind), zeige einen "Rahmungsfehler” an. 



TTY- 

EMPFANGS- 

BETRIEB 


Bild 11-34 Flußdiagramm für Empfangs-Veifahren, 


11-116 


11-117 









Aufgabe: Daten lesen 

Zweck: Hole Daten von einem Fernschreiber über Bit 7 des VIA-Datenports und 
plaziere die Daten in den Speicherplatz 0046. Für das Verfahren siehe 
Bild 11-34. 

Quellprogramm: 

(Es werde angenommen, daß der serielle Port Bit 7 des VIA ist und daß keine 
Parität oder Rahmung erforderlich ist). 
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Objektprogramm: 


Speicher Adresse 

Speicher-Inhalt 


Befehl 

(Hex) 

(Hex) 


(Mnemonik) 

0000 

A9 


LDA 

#0 

0001 

00 




0002 

8D 


STA 

VlAPCR 

00031 

VlAPCR 




0004 t 




0005 

8D 


STA 

VIAODRA 

00061 

VlADDRA 




0007t 




0008 

AD 

WAlTS 

LDA 

VIAORA 

00091 

000Al 

VIAORA 




0008 

30 


8MI 

WAlTS 

oooc 

FB 




000D 

20 


JSR 

DLY2 

000E 

30 




000F 

00 




OOtO 

A9 


LDA 

#%10000000 

0011 

80 




0012 

20 

TTYRCV 

JSR 

DELAY 

0013 

34 




0014 

00 




0015 

2E 


ROL 

VIAORA 

00161 

00171 

VIAORA 




0018 

6A 


ROR 

A 

0019 

90 


BCC 

TTYRCV 

001A 

F7 




001 B 

85 


STA 

$60 

OOlC 

60 




001D 

00 


BRK 


0030 

AO 

DLY2 

LDY 

#5 

0031 

05 




0032 

DO 


BNE 

DLY1 

0033 

02 




0034 

AO 

DELAY 

LDY 

#10 

0035 

OA 




0036 

A2 

DLY1 

LDX 

#$84 

0037 

B4 




0038 

CA 

DLY 

DEX 


0039 

DO 


BNE 

DLY 

003A 

FD 




003B 

88 


DEY 


003C 

DO 


BNE 

DLY1 

003D 

F8 




003E 

60 


RTS 
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Dieses Programm nimmt an. daß der Stapel für Unferprogramm-Aufrute verwen¬ 
det werden kann. d.h. daß der Monitor den Stapelzeiger bereits initialisiert hat. 
Andernfalls muß man den Stapelzeiger so initialisieren, wie in Kapitel 1 0 gezeigt 
wurde. 

Die Konstanten für die Verzögerungs-Routine wurden berechnet, wie früher in 
diesem Kapitel gezeigt wurde. Sie können versuchen sie selbst zu bestimmen 
Die Verzögerungen müssen nicht zu genau sein, da der Empfang zentriert ist, 
die Nachrichten kurz sind, die Datenrate niedrig ist und der Fernschreiber selbst 
keine sehr hohe Genauigkeit besitzt. 

Wie würden sie dieses Programm eiweitem, um die Parität zu prüfen? 
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Aufgabe 2: Schreiben von Daten 

Zweck: Sende Daten zu einem Fernschreiber über Bit 0 eines VIA-Ausgangs 
(Daten)-Register. Die Daten liegen im Speicherplatz 0060 


Senden (Flußdiagramm in Bild 11 35): 

Schritt 1) Sende ein Start-Bit (d.h. eine logische Eins). 

Schritt 2) Sende die sieben Datenbits, beginnend mit dem niedrigstwertigen Bit. 
Schritt 3) Erzeuge und sende das Paritäts Bit. 

Schritt 4) Sende zwei Stop-Bits (d.h. logische Einsen). 

DieSende-Routine muß für die Zeit eines Bits zwischen jeder Operation warten. 
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Quellprogramm: 

(Es werde angenommen, daß keine Parität erzeugt werden muß) 


LDA 

#0 

STA 

VIAPCR 

STA 

VIAORB 

LDA 

#$FF 

STA 

VIADDRB 

LDA 

$60 

LDX 

#11 

JSR 

SEC 

DELAY 

ROR 

A 

ROL 

DEX 

VIAORB 

BNE 

BRK 

TBIT 


;MACHE ALLE STEUER-LEITUNGEN ZU 
AUSGÄNGEN 
:BILDE START-BIT 

.MACHE PORT-B-LEITUNGEN ZU 
AUSGANGEN 
;HOLE DATEN 

.ZÄHLUNG - 11 BITS IM ZEICHEN 
;WARTE FÜR OIE ZEIT EINES BITS 
;SETZE ÜBERTRAG ZUR BILDUNG EINES 
; STOP-BITS 

;HOLE NÄCHSTES BIT DES ZEICHENS 
.SENDE NÄCHSTES BIT ZU TTY 


Das hier verwendete DELAY-Unterprogramm muß den Akkumulator und das In 
dex-Register X aufbewahren. Erinnern Sie sich daran, daß Bit 0 der Daten 
zuerst gesendet werden muß 
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In tatsächlichen Anwendungen werden Sie finden, daß es eiforderlich ist, eine 
Eins auf die Fernschreibleitung nach jeder Konfiguration zu plazieren, da die 
Leitung im Eins-(Mark)-Zustand sein sollte, wenn keine Daten gesendet werden. 


Jedes Zeichen besieht aus 11 Bits, beginnend mit einem Stail-Bit (Null) und en¬ 
dend mit zwei Slop-Bits (Einsen) 

Beachten Sie, daß Sie eine Parität durch Zählen der Bits erzeugen können, wie 
in Kapitel 6 gezeigt wird Das Programm lautet: 



LDY 

#0 


LDA 

$60 

CHBIT 

BPL 

INY 

CHKZ 

CHKZ 

ASL 

A 


BNE 

BRK 

CHBIT 


BITZAHLUNG-NULL 
HOLE DATEN 

IST NÄCHSTES DATENBIT 1? 

JA, ADDIERE 1 ZUR BITZÄHLUNG 
PRÜFE NÄCHSTE BIT-POSITION 
BIS ALLE BITS NULLEN SIND 


Das Indexregister Y enthält die Anzahl der 1 - Bits in den Daten. Das medngst- 
wertige Bit des Indexregisters Y ist deshalb ein gerades Paritätsbit 


Diese Verfahren sind zwar gebräuchlich, jedoch so kom- | UART 

plex, um einen speziellen LSI-Baustein zu rechtfertigen, den 
UART, oder Universal Asynchronous Receiver/Transmitter (Universeller asyn¬ 
chroner Emptänger/Sender) 24 . Der UART wird das Empfangs-Verfahren durch¬ 
führen und Daten in paralleler Form, sowie das "Data-Ready"-Signal liefern. Er 
wird auch Daten in paralleler Form aufnehmen, das Sende-VeHahren ausführen 
und ein "Peripheral Ready"-Signal liefern, wenn er weitere Daten verarbeiten 
kann UARTs besitzen zahlreiche andere Eigenschaften, und zwar: 


1) Die Fähigkeit, unterschiedliche Bitlängen zu verarbeiten (gewöhnlich 5 bis 8), 
wahlweise Parität und die Anzahl der Stop-Bits (gewöhnlich 1. 1-1/2, und 2). 

2) Anzeigen für Rahmungstehler, Paritätsfehler und "Überlauf-Fehler" (Fehler 
durch das Lesen eines Zeichens, bevor ein anderes empfangen wird). 

3) Kombatibilität mit RS-232 25 , d.h. ein Ausgangs-Signal "Sende-Anforderung" 
(RTS- Request to Send), das die Anwesenheit von Daten zum Kommum'ka- 
tionsgerät anzeigt und ein Eingangs-Signal "Sende-Bereitschaft" (CTS - 
Clear lo Send), das als Antwoil auf RTS die Bereitschaft des Kommunika¬ 
tionsgerätes anzeigt. Es können auch Vorkehrungen für andere RS-232-Si- 
gnale vorhanden sein, wie "Received Signal Ouality", "Data Set Ready" oder 
"Data Terminal Ready”. 

4) Tristate-Ausgänge und Steuer-Kompatibilität mit einem Mikroprozessor. 

5) Takt-Optionen, die dem UART gestatten, die ankommenden Daten mehrere 
Male abzutasten, um falsche Start-Bits und andere Fehler festzustellen. 

6) Unterbrechungs-Möglichkeiten und Steuerungen 

UARTs dienen als vier parallele Ports: Ein Eingangs-Daten-Port, ein Ausgangs- 
daten-Port, ein Eingangs-Slatusport und ein Ausgangs-Steuerport Die Status- 
Bits enthalten Fehleranzeigen, sowie Bereit-Flags (Ready-Flags). Die Steuer-Bits 
wählen verschiedene Optionen aus. UARTs sind preisgünstig (10.- bis 100.- 
DM, abhängig von ihren Eigenschaften) und leicht zu verwenden. 


DER ASYNCHRONE KOMMUNIKATIONS-INTERFACE¬ 
ADAPTER 6850 (ACIA) 2e > 27 

Der ACIA 6850 oder asynchrone Kommunikations- 
Interface-Adapter (siehe Bild 11-36) ist ein UART, der spe¬ 
ziell für die Verwendung in Mikrocomputer-Systemen mit 
dem 6800 und 6502 entwickelt wurde. Er belegt zwei Speicher-Adressen und 
enthält zwei "Nur-Lese’'-Register: (empfangene Daten und Status) und zwei 
"Nur-Schreib"-Register (gesendete Daten und Steuerung). Die Tabellen 11-16 
und 11-17 beschreiben den Inhalt dieser Register. 

Beachten Sie die folgenden speziellen Eigen¬ 
schaften des ACIA: 

1) Lese- und Schreib-Zyklen adressieren physi¬ 
kalisch bestimmte Register Deshalb kann man 
die ACtA-Register nicht als Adressen für Befehle 
wie "Inkrementiere", "Dekrementiere” oder "Verschiebe" verwenden, die so¬ 
wohl Lese-wie Schreibzyklen enthalten. 

2) Das ACtA-Steuerregister kann nicht von der CPU gelesen werden. Man muß 
eine Kopie des Steuerregisters im Speicher autbewahren. wenn das Pro¬ 
gramm seinen Wert benötigt. 

3) Der ACIA besitzt keinen RESET-Eingang Er kann nur durch das Plazieren 
von Einsen in die Steuerregister-Bits 0 und 1 gelöscht werden. Dieses Ver¬ 
fahren (genannt MASTER RESET) ist erforderlich, bevor der ACIA eingesetzt 
wird, um zu vermeiden, daß er ein zufälliges Start-Zeichen besitzt. 

4) Die RS-232-Signale sind alle aktiv Low. Reöuest-to-Send (RTS) sollte insbe- 
sonders auf High gebracht werden, um es inaktiv zu machen, wenn es nicht 
in Verwendung steht. 

5) Der ACIA benötigt einen externen Takt. Gewöhnlich werden 1760 Hz zuge- 
tührt und die Betriebsart -^16 (Steuerregister-Bit 1-0, Bit 0 - 1) verwendet 
Der ACIA wird den Takt zur Zentrierung des Empfangs verwenden, um fal¬ 
sche Start-Bits zu vermeiden, die durch Rauschen aut den Leitungen verur¬ 
sacht werden könnten. 

6) Das "Dala-Ready"-Flag (Emptangsdaten-Register voll, oder Receive-Data- 
Register-Full RDRF) ist Bit 0 des Status-Registers. Das Penpheral-Ready- 
Flag (Sendedaten-Register leer, oder Transmit-Data-Register-Empty «= TDRE) 
ist Bit 1 des Status-Registers. 


SPEZIELLE 

EIGENSCHAFTEN 

DESACIA 


ACIA- 

REGISTER 
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Tabelle 11-16. Definition des Inhalts der ACIA-Register. 


Tabelle 11-17 Bedeutung der ACIA Steuerregister-Bits. 


Puffer-Adresse 


Daten¬ 

bus 

Zeilen- 

Nummer 

RS- R/W 
Sende- 
Daten- 
Register 

RS•R/W 
Empfangs- 
Daten- 
Register 

RS R/W 

Steuer- 

Register 

RS R/W 

Status- 

Register 


(Nur Schreiben) 

(Nur L*s*n) 

(Nur Schreiben) 

{Nur Lesen) 

0 

Data Bit 0’ 

Data Bit 0 

Counter Divide 
Select 1 tCROI 

Receive Data Register 
Full (RDRF) 

1 

Data Bit 1 

Data Bit 1 

Counter Divide 
Select 2 (CR1) 

Transmit Data Register 
Empiv (TDREI 

2 

Data Bit 2 

Data Bit 2 

Word Select 1 
(CR21 

Data Carrier Detect 
(DCDI 

3 

Data Bit 3 

Data Bit 3 

Word Select 2 
(CR3I 

Clear to-Send 
(CTSI 

4 

Data Bit 4 

Data Bit 4 

Word Select 3 
ICR4) 

Frammg Error 
(FE) 

5 

Data Bit 5 

Data Bit 5 

Transmit Control 1 
(CR5) 

Receiver Overrun 
(OVRN) 

6 

Data Btt 6 

Data Bit 6 

Transmil Control 2 
(CR6) 

Panty Error (PE) 

7 

Data Bit 7'" 

Data Bit 7" 

Receive Interrupt 
Enable (CR7) 

Interrupt Request 
(IRQ) 


* Führendes Bit - LSB - Bit 0 

'* Datenbit wird null in der Betriebsart 7 Bit plus Parität sein 
’** Datenbit ist "beliebig" in der Betriebsart 7 Bit plus Parität 


CR6 

CR5 

Funktion 

0 

0 

RTS- Low, Sende-Unterbrechung gesperrt, 

0 

1 

RTS= Low, Sende-Unterbrechung Ireigegeben. 

1 

0 

RTS- High, Sende-Unterbrechung gesperrt. 

1 

1 

RTS =Low. Sendet ein Signal für eine Unter- 



brechung auf dem Sende-Datenausgang 



Sende Unterbrechung gesperrt. 

CR4 

CR3 

CR2 

Funktion 

0 

0 

0 

7 Bits + Gerade Parität + 2 Stop Bits 

0 

0 

1 

7 Bits + Ungerade Parität + 2 Stop-Bits 

0 

1 

0 

7 Bits + Gerade Parität + 1 Stop-Bit 

0 

1 

1 

7 Bits+ Ungerade Parität + 1 Stop-Bit 

1 

0 

0 

8 Bits + 2 Stop-Bits 

1 

0 

1 

8 Bits+ 1 Stop-Bit 

1 

1 

0 

8 Bits+ Gerade Parität + 1 Stop-Bit 

1 

1 

1 

8 Bits+ Ungerade Parität + 1 Stop-Bit 

CR1 

CRO 

Funktion 

0 

0 


+■ 1 

0 

1 


16 

1 

0 


-t- 64 

1 

1 


Haupt-Reset 
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R«ad/Wr»ie« 
Oi* Seiect 0 
ChiO Se*ect 1 



Aufgabe: Empfange Oaten von einem Fernschreiber Uber einen ACIA 6850 und 
plaziere die Oaten in den Speicherplatz 0040. 


Quellprogramm: 


LDA 

#%00000011 

MASTER RESET FÜR ACIA 

STA 

ACIACR 


LDA 

#%01000101 

.KONFIGURIERE ACIA FÜR TTY MIT 
, UNGERADER PARITAT 

STA 

ACIACR 


WAITD LDA 

ACIASR 

.HOLE ACIA-STATUS 

LSR 

A 

.WURDEN DATEN EMPFANGEN? 

BCC 

WAITD 

.NEIN, WARTE 

LDA 

ACIADR 

,JA, HOLE DATEN VOM ACIA 

STA 

BRK 

$60 

.BEWAHRE DATEN AUF 


Objektprogramm: 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) 

0000 

A9 

LDA 

#%00000 011 

0001 

03 



0002 

8D 

STA 

ACIACR 

00031 

00041 

ACIACR 



0005 

A9 

LDA 

#%01000101 

0006 

45 



0007 

8D 

STA 

ACIACR 

0008 t 

0009) 

ACIACR 



000A 

AD 

WAITD LDA 

ACIASR 

00081 

OOOC) 

ACIASR 



000D 

4A 

LSR 

A 

000E 

90 

BCC 

WAITD 

000F 

FA 



0010 

AD 

LDA 

ACIADR 

00111 

0012) 

ACIADR 



0013 

86 

STA 

$60 

0014 

60 



0015 

00 

BRK 



Das Programm muß den ACIA anfangs löschen, indem es Einsen in die Steuer¬ 
register Bits 0 und 1 plaziert. Der ACIA besitzt kein internes Löschen beim Ein¬ 
schalten der Betriebsspannung, das den ACIA im Reset-Status hält, bis der 
"Master-Reset" zugeführt wird 
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Dieses Programm konfiguriert das ACIA-Steuer- BEISPIEL FÜR ACIA- 

Register wie folgt; KONFIGURATIONEN 


Aufgabe: Sende Daten vom Speicherplatz 0040 zu einem Fernschreiber über 
einen ACIA 6850. 


Bit 7 = 0, um die Empfänger-Unterbrechung zu sperren 


Quellprogramm: 


Bit 6- 1, um Re^uest-to-Send (RTS) High (inaktiv) zu machen. 

LDA 

*%00000011 

;MASTER-RESET FÜR ACIA 


STA 

ACIACR 


Bit 5-0, um die Sender-Unterbrechung zu sperren. 

LDA 

#%01000101 

;KONFIGURIERE ACIA FÜR TTY MIT 




, UNGERADER PARITÄT 

Bit 4 = 0, für 7-Bit-Worte 

STA 

ACIACR 



LDA 

#%00000010 


Bit 3 = 0. Bit 2 = 1 für ungerade Pantät mit zwei Stop-Bits 

WAHR BIT 

ACIASR 

,IST DER ACIA BEREIT FÜR DATEN? 


BEO 

WAHR 

NEIN, WARTE BIS ES DER FALL IST 

Bit 1 = 0, Bit 0 - 1 für Takt dividiert durch 16 (es müssen 1760 Hz zuge¬ 

LDA 

S60 

;JA, HOLE DATEN 

führt werden.) 

STA 

ACIADR 

,UND SENDE SIE 


BRK 




Das empfangene Daten-Statusbit ist Statusregister-Bit 0. Was würde gesche¬ 
hen, wenn wir versuchen Objektprogramm: 


LDA ACIASR 
LSR A 


durch 

LSR ACISR 
zu ersetzen? 

Erinnern wir uns daran, daß sich die Status- und Steuerregister eine Adresse 
teilen, jedoch physikalisch voneinander getrennt sind. 

Versuchen Sie eine Fehlerprüf-Routine in das Programm einzufügen. Setze: 

(0061) - 0, wenn keine Fehler auftraten 

= 1, wenn ein Paritätsfehler auftrat 
(Statusregister-Bit 6-1) 

-2. wenn ein Überlauf-Fehler auftrat 
(Statusregister-Bit 5 = 1) 

- 3, wenn ein Rahmungsfehler auftrat 
(Statusregister-Bit 4 = 1) 

Nehmen Sie an, daß die Priorität von Fehlern vom MSB zum LSB im ACIA-Sta- 
tusregister geht (d.h. Paritätsfehler haben die Priorität vor Überlaulfehlern, die 
wiederum Priorität vor Rahmungsfehlern haben, wenn mehr als ein Fehler aul¬ 
getreten ist). 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 


Befehl 

(Mnemonik) 

0000 

A9 


LDA 

#%00000011 

0001 

03 




0002 

8D 


STA 

ACIACR 

00031 

00041 

ACIACR 




0005 

A9 


LDA 

#%0l000101 

0006 

45 




0007 

8D 

STA 

ACIACR 


0008 t 

0009» 

ACIACR 




000A 

A9 


LDA 

#%00000010 

0008 

02 




oooc 

2C 

WAITR 

BIT 

ACIASR 

000DI 

000E1 

ACIASR 




000F 

F0 


BEQ 

WAITR 

0010 

FB 




0011 

A5 


LDA 

$60 

0012 

60 




0013 

SD 


STA 

ACIADR 

0014t 

00151 

ACIADR 




0016 

00 


BRK 



Das Sender-Statusbit ist das Statusregister-Bit 1. Wie könnten Sie das Em¬ 
pfangsprogramm modifizieren, um den Bit-Test Befehl zu verwenden? 
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DER ASYNCHRONE KOMMUNIKATIONS-INTERFACE¬ 
ADAPTER (ACIA) 6551 


Der 6551 ACIA ist eine Variante des Bausteins 6650, der 6551 ACIA- 
sowohl In Systemen mit dem 6600 wie dem 6502 verwen- ocrRTPR 

det werden kann. Bild 11 37 zeigt ein Blockschaltbild die- - 

ses Bausteins. Er besitzt die meisten Eigenschaften des ACIA 6650 und ent¬ 
hält auch einen Baud-Raten-Generator, der 15 programmierbare Baudraten, 
abgeleitet von einem externen Quarz mit 1.8432 MHz liefern kann. Daher kann 
der ACIA 6551 nahezu jede gebräuchliche Baudrate ohne externen Zeitge¬ 
ber oder Baudraten-Generator liefern. Dieser Baustein besitzt vier interne Re¬ 


gister, die gemäß Tabelle 11-18 adressiert werden. Seine Arbeitsweise wird 
durch zwei Register gesteuert. 


1) Das Steuerregister (siehe Bild 11 38) steuert den Baudraten-Generator, die 
Wortlänge, die Anzahl der Stopbits, und die Taktquelle des Empfängers 

2) Das Kommandoregister (siehe Bild 11 39) BEISPIEL EINER 
steuert die Paritäts-Prüfung und Erzeugung, KONFIGURATION DES 
Unterbrechungs-Freigabe und die Ouittie- ACIA 6551 
rungssignale für RS-232. Beachten Sie. daß 

das Programm den ACIA 6551 jederzeit zurücksetzen kann, indem irgend¬ 
welche Daten in die Adresse des Statusregisters (siehe Bild 11 40) geschne- 
ben werden. Zum Beispiet löscht das folgende Programm den ACIA 6551 
und konfiguriert ihn für einen Fernschreiber mit 10 Zeichen pro Sekunde, un¬ 
gerader Parität und zwei Stop Bits; 


LDA #%10110011 

STA ACIASR ;RESET FÜR 6551 ACIA 

STA ACIAMR ;KONFIGURIERE BETRIEBSART FÜR TTY 

(7 BITS. 2 STOPBITS) 

LDA #%00100011 

STA ACIACR KONFIGURIERE UNGERADE PARtTAT, 

; KEINE UNTERBRECHUNGEN 


Wir haben dem Steuer- (Betriebsart)-Register den Namen ACIAMR gegeben 

Das Programm konfiguriert das Steuer (Betriebsart)-Register des ACIA 6551 wie 
folgt: 


Bit 7 1. für zwei Stopbits 

Bit 6 0. Bit 5 = 1 für 7-Bit-Worte 

Bit 4 - 1, um einen Empfanger-Takt vom internen Generator zu erzeugen 
Bits 0 - 3=0011 für 109.92 Baud (10 Zeichen pro Sekunde) vom internen 
Baudiaten-Generator 


Das Programm konfiguriert das Kommandoregister des ACIA 6551 wie folgt; 

Bit 7 = 0, Bit 6 - 0, Bit 5- 1 für ungerade Pantät sowohl für Empfänger wie 
Sender 

Bit 4 = 0, damit Zeichen nicht automatisch zurück durch den Sender aus¬ 
gesandt werden 

Bit 3-0, Bit 2 -0, um die Sender-Unterbrechung zu sperren und RTS auf 
High (inaktiv) zu bringen 

Bit 1 - 1. um die Empfänger Unterbrechung zu sperren (dies ist ein Mas¬ 
kenbit) 

Bit 0-1, um den Empfänger/Sender freizugeben 
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Bild 11-38. Definition des Inhalts des Steuer-Registers des ACIA 6551. 
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LOGISCHE UND PHYSIKALISCHE BAUSTEINE 28 


Ein wesentlicher Vorteil beim Schreiben von E/A-Routinen 
besteht darin, sie unabhängig von spezieller physikali¬ 
scher Hardware zu machen. Die Routinen können dann Da- 


LOGISCHE 

BAUSTEINE 


ten zu oder von E/A-Bausteinen transferieren, wobei die tatsächlichen Adres¬ 
sen als Parameter geliefert werden. Auf den E/A-Baustein kann in Wirklich¬ 
keit über ein spezielles Interface zugegriffen werden, der als physikalischer 
Baustein bezeichnet wird. Der E/A-Baustein, zu dem das Programm Daten 


transferiert, wird als logischer Baustein bezeichnet. Das Betriebssystem oder 


Uberwachungsprogramm muß eine Anordnung (mapping) der logischen Bau¬ 
steine liefern, die auf den physikalischen Bausteinen liegen, das heißt, tat¬ 
sächliche physikalische E/A-Adressen und Eigenschaften so zuzuordnen, daß 


sie von E/A-Routinen verwendet werden können. 


Beachten Sie die Vorteile dieser Lösung: 

1) Das Betriebssystem kann die Zuweisung unter der Steuerung des Anwen¬ 
ders variieren. Beachten Sie, daß der Anwender leicht einen Test-Panel oder 
ein Entwicklungssystem-Interface gegen die tatsächlichen E/A-Bausteine 
austauschen kann. Dies ist sehr nützlich bei Wartungsarbeiten, sowie bei der 
Fehlersuche und beim Testen. Ferner kann der Anwender die E/A-Geräle für 
verschiedene Situationen austauschen. Typische Beispiele wären die Ausga¬ 
be von Zwischenergebnissen zu einer Video-Anzeige und die endgültige 
Ausgabe zu einem Drucker oder die Eingabe von einer Fernsteuerungs- 
Leitung anstatt von einer lokalen Tastatur. 

2) Die gleichen E/A-Routinen können mehrere identische oder ähnliche Bau¬ 
steine handhaben. Das Betriebssystem oder der Anwender braucht zum Bei¬ 
spiel nur die Adresse eines speziellen Fernschreibers, RS-232 Terminals 
oder Druckers zu liefern. 

3) Änderungen, Korrekturen oder Ergänzungen zur E/A-Konfiguration sind 
leicht auszuführen, da nur die Zuweisungen (oder die Anordnungen) geän¬ 
dert werden müssen. 


Beim Mikroprozessor 6502 kann entweder die vor-indizierte (indizierte indirekte) 
oder nach-indizierte (indirekte indizierte) Adressier-Art bei den E/A-Routinen 
verwendet werden, um eine Unabhängigkeit von speziellen physikalischen 
Adressen zu erreichen. Vor-Indizierung ist bequem, da sie die Auswahl ver¬ 
schiedener physikalischer Baustein-Adressen von einer Tabelle gestatten. 
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Wenn eine Tabelle von E/A-Adressen auf Seite Null 
aufbewahrt wird, ist alles, was eine E/A-Adresse 
benötigt, ein Index in diese Tabelle. Sie kann dann 
auf den E/A-Baustein unter Verwendung der vor-indizierten (oder indizierten 
indirekten) Adressier-Art zugreifen. Wenn zum Beispiel die Baustein-Nummer im 
Speicherplatz DEV liegt, würde das Programm zur Berechnung des 
Index lauten: 


E/A-BAUSTEIN- 

TABELLE 


LDA DEV 
ASL A 

TAX 


HOLE BAUSTEIN NUMMER 
MULTIPLIZIERE MIT 2 FÜR 2-BYTE- 
ADRESSENTABELLEN 


Daten können nun von oder zum entsprechenden E/A-Baustein mit folgenden 
Befehlen transferiert werden 


LDA DATA 
STA (IOTBL.X) 


HOLE DATEN 

SENDE DATEN ZUM LOGISCHEN 
E/A-BAUSTEIN 


oder 


LDA (IOTBL.X) 
STA DATA 


HOLE DATEN VOM LOGISCHEN 
E/A-BAUSTEIN 
BEWAHRE DATEN AUF 


Die gleiche E/A-Routme kann Daten zu oder von mehreren verschiedenen 
E/A-Bausteinen transferieren, indem sie einfach mit unterschiedlichen Indizes 
versehen werden. Vergleichen Sie die Flexibilität dieser Lösung mit der gerin¬ 
gen Flexibilität von E/A-Routinen. die direkte Adressierung verwenden und 
deshalb zu speziellen physikalischen Adressen geführt werden. 


STANDARD-INTERFACES 

Andere Standard-Interfaces neben der TTY-Stromschleife 
und RS-232 können ebenfalls verwendet werden, um peri¬ 
phere Geräte mit dem Mikrocomputer zu verbinden. Einige 
bekannte sind: 

1) Die seriellen Interfaces RS-449, RS 422 und RS-423 29 

2) Der parallele universelle Interface-Bus (Generai-Purpose-Inteiiace-Bus - 
GPIB) auch bekannt als IEEE 488 oder Hewlett-Packard Interface-Bus 
(HPIB). 30 

3) Der Hobby-Computerbus oder Altair/Imsai-Bus S-1 00. 31 Dies ist ebenfalls ein 
8-Bit-Bus. 

4) Der Intei-Multibus. 33 Dies ist ein weiterer 8-Bit-Bus, der jedoch erweitert wer¬ 
den kann, so daß er 16 Bits parallel verarbeitet. 


STANDARD¬ 

INTERFACES 
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AUFGABEN 


1) Trennung von Tastenbetätigungen von einer nicht codier¬ 
ten Tastatur 

Zweck: Das Programm sollte Eingaben von einer nicht codierten 3x3-Ta- 
statur lesen und sie in eine Anordnung plazieren. Die Anzahl 
der erorderlichen Eingaben befinden sich im Speicherplatz 0040 
und die Anordnung beginnt im Speicherplatz 0041. 

Trennen Sie eine Tastenbeläligung von der nächsten, indem Sie auf das Ende 
der momentanen Tastenbeläligung warten. Vergessen Sie nicht, die Tastatur zu 
entprellen (dies kann einfach ein Warten von 1 ms sein) 

Beispiel: 

(0040) - 04 

Eingaben sind 7, 2, 2, 4 

Ergebnis: (0041) - 07 

(0042) - 02 
(0043) - 02 
(0044) - 04 


2) Lesen eines Satzes von einer codierten Tastatur 

Zweck: Das Programm sollte die Eingaben von einer ASCII-Tastatur lesen (7 
Bits mit einem Nuii-Parilälsbit) und es in eine Anordnung plazieren, 
bis es einen ASCII-Punkt 2Eis empfängt. Die Anordnung beginnt im 
Speicherplatz 0040. Jede Eingabe ist durch einen Tast-Impuls mar¬ 
kiert, wie In dem Beispiel "Eine codierte Tastatur". 

Beispiel: 

Eingaben sind H, E, L, L, 0,. 

Ergebnis: (0040) - 48 H 

(0041) - 45 E 
(0042) - 4C L 
(0043) ■ 4C L 
(0044) - 4F O 
(0045) - 2E 
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3) Ein Rechteck-Generator mit variabler Amplitude 

Zweck: Das Programm sollte eine Rechteck-Welle erzeugen, wie im näch¬ 
sten Bild gezeigt ist, unter Verwendung eines D/A-Wandlers. Der 
Speicherplatz 0040 enthält die geeichte Amplitude der Welle, der 
Speicherplatz 0041 die Länge eines Halbzyklus in Millisekunden, 
und der Speicherplatz 0042 die Anzahl der Zyklen. 

Nehmen Sie an. daß eine digitale Ausgabe von 80 ls zum Konverter in einem an¬ 
alogen Ausgangssignal von null Volt resultiert. Im allgemeinen ergibt eine digi¬ 
tale Ausgabe von D ein analoges Ausgangssignal von (D-80J/80 X -V R ^p Volt. 

Beispiel: 

(0040) - A0 (hex) 

(004 f) - 04 
(0042) = 03 


Ergebnis: 

♦ | 



Oie Basis-Spannung Ist 80,« - 0 VOR Sie volle Skala belrägt 1 0G„ =-v^^p Volt. 

Daher ist A0« - (AD-flOt/SO X-VR£f = -V 

Das Programm erzeugt 3 Impulse mit der Amplitude V RE p/4 mit einer halben 
Zyklus-Länge von 4 ms. 


4) Mittelwert-Bildung von analogen Ablesungen 

Zweck: Das Programm sollte vier Ablesungen von einem A/D-Wandler im Ab¬ 
stand von 1 0 Millisekunden entnehmen und den Mittelwert in den Spei¬ 
cherplatz 0040 legen. Es werde angenommen, daß der A/D-Wandler 
100 Mikrosekunden für eine Umwandlung benötigt, so daß die Umwand¬ 
lungszeit ignoriert werden kann. 

Beispiel: 

Ablesungen sind (hex) 86, 89, 81. 84 

Ergebnis: (0040) = 85 


5) Ein Terminal mit 30 Zeichen pro Sekunde 

Zweck: Modifiziere die Sende- und Empfangs-Routinen für das Beispiel "Ein 
Fernschreiber", um ein Terminal mit 30 Zeichen/Sekunde zu steuern, 
das ASCII-Dalen mit einem Slop-Bil und gerader Parität überträgt. Wie 
könnten Sie die Routinen schreiben, um jedes Terminal zu steuern, ab¬ 
hängig von einem Flag-Bit im Speicherplatz 0060. D.h. Zeichen/Sekun¬ 
de (0060) - 0 für das Terminal mit 30 Zeichen/Sekunde, (0060) - 1 für 
das Terminal mit 10 Zeichen/Sekunde? 
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Kapitel 12 

UNTERBRECHUNGEN 


Unterbrechungen sind Eingaben, die die CPU als Teil jedes Befehls-Zyklus 
prüft. Diese Eingaben gestatten der CPU, auf Vorgänge mehr auf Hardware- 
Ebene zu reagieren als auf Software-Ebene über das Prüfen jedes Bausteins 
(polling = Abfragen). Unterbrechungen benötigen im allgemeinen mehr Hard¬ 
ware als eine gewöhnliche (programmierte) E/A, ergeben Jedoch eine schnel¬ 
lere und direktere Reaktion.' 


Weshalb verwendet man Unterbrechungen? 

Unterbrechungen gestatten es, die unmittelbare 
Aufmerksamkeit der CPU auf Vorgänge zu er¬ 
langen, wie etwa Alarm, Betriebsspannungs-Ausfall, das Einfügen von Zeil-In- 
teivallen und periphere Bausteine, die über Daten verfügen oder bereit sind, Da¬ 
ten anzunehmen. Der Programmierer muß nicht erst dafür sorgen, daß jede 
mögliche Datenquelle abgefragt wird, und braucht sich nicht um nicht vorhan¬ 
dene Vorgänge zu kümmern. Ein Unterbrechungs-System entspricht etwa einer 
Telefonklingel, sie läutet, wenn ein Aufruf empfangen wird, so daß man den Hö¬ 
rer nicht laufend abnehmen muß um festzustellen, ob sich jemand in der Leitung 
befindet. Die CPU kann ihre normale Tätigkeit ausführen (und verschwendet da¬ 
durch weniger Zeit). Wenn irgend etwas geschieht, so macht sich die Unterbre¬ 
chung bei der CPU bemerkbar und zwingt sie dazu, die Eingabe zu bedienen, 
bevor sie ihre normalen Operationen fortsetzt. Natürlich wird diese einfache Be¬ 
schreibung wesentlich komplizierter (wie etwa das Schaltbrett eines Telefons), 
wenn es mehrere Unterbrechungen unterschiedlicher Wichtigkeit gibt, sowie 
Aufgaben, die nicht unterbrochen werden dürfen. 


Die Ausführungen von Unterbrechungs- 
Systemen unterscheiden sich sehr stark. Unter 
den zu beantwortenden Fragen für die Charakte¬ 
risierung eines speziellen Systems sind: 


1) Wieviele Unterbrechungs-Eingänge gibt es? 

2) Wie reagiert die CPU auf eine Unterbrechung? 

3) Wie bestimmt die CPU die Quelle einer Unterbrechung, wenn die Anzahl der 
Quellen die Anzahl der Eingänge überschreitet? 

4) Kann die CPU zwischen wichtigen und unwichtigen Unterbrechungen unter¬ 
scheiden? 

5) Wie und wann wird das Unterbrechungs-System freigegeben und gesperrt? 

Es gibt zahlreiche unterschiedliche Antworten auf diese Fragen. Der Zweck aller 
dieser Ausführungen besteht jedoch darin, daß die CPU rasch auf Unterbre¬ 
chungen reagiert und danach wieder Ihre normale Tätigkeit aufnimmt. 


EIGENSCHAFTEN 

VON 

UNTERBRECHUNGS¬ 

SYSTEMEN 


BEGRÜNDUNG FÜR 
UNTERBRECHUNGEN 
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Die Anzahl der Unterbrechungs-Eingänge auf dem CPU-Chlp bestimmt die An¬ 
zahl der verschiedenen Reaktionen, die die CPU ohne zusätzliche Hardware 
oder Software hervorbringen kann. Jeder Eingang kann eine unterschiedliche 
interne Reaktion bewirken. Unglücklicherweise besitzen die meisten Mikropro¬ 
zessoren eine sehr kleine Anzahl (typisch t oder 2) getrennter Unterbrechungs- 
Eingänge. 


Die eigentliche Reaktion der CPU auf eine Unterbrechung muB die Übergabe 
der Steuerung zur richtigen Unterbrechungs-Servlce-Routine sein und die Auf¬ 
bewahrung des momentanen Weites des Befehlszählers. Die CPU muß daher 
eine Befehl "Springe zu Unterprogramm" oder Aufrufbefehl mit dem Beginn der 
Unterbrechungs-Service-Routine an dieser Adresse ausführen. Diese Aktion 
wird die Rückkehr-Adresse im Stapel aufbewahren und die Steuerung der Unter¬ 
brechungs-Service-Routine übergeben. Der Umfang der benötigten externen 
Hardware für diese Reaktion variiert in hohem Maße. Einige CPUs erzeugen den 
Befehl und die Adresse intern. Andere benötigen externe Hardware, um dies 
auszuführen. Die CPU kann nur einen unterschiedlichen Befehl oder Adresse für 
jeden separaten Eingang erzeugen. 


Wenn die Anzahl der unterbrechenden Bausteine die 
Anzahl der Eingänge überschreitet, benötigt die CPU 
zusätzliche Hardware oder Software, um die Quelle der 
Unterbrechung zu identifzieren. Im einfachsten Fall 
kann die Software eine Abfrage-Routine (Polling-Routine) sein, die den Status 
der Bausteine prüft, von denen eine Unterbrechung zu erwarten ist Der einzi¬ 
ge Vorteil eines derartigen Systems gegenüber dem normalen Abfragen be¬ 
steht darin, daß die CPU weiß, daß wenigstens ein Bauatein aktiv Ist. Die an¬ 
dere Lösung besteht aus zusätzlicher Hardware, um eine eindeutige Daten- 
Eingabe (oder "Vektor") für jede Quelle zu liefern. Die beiden Alternativen kön¬ 
nen auch gemischt verwendet werden. Die Vektoren können Gruppen von Ein¬ 
gängen identifizieren, von denen die CPU einen speziellen hiervon durch Ab¬ 
fragen (polling) Identifizieren kann. 


ABFRAGEN 

VEKTORISIEREN 


PRIORITÄT 


Ein Unterbrechungs-System, das zwischen wichtigen 
und unwichtigen Unterbrechungen unterscheiden kann, 
wird ein "Prior'itäte-Unterbrechungssystem” genannt. Interne Hardware kann 
so viele Prioritäte-Ebenen liefern, wie es Eingänge gibt. Externe Hardware 
kann zusätzliche Ebenen durch die Verwendung eines Prioritätsregisters und 
Komparators zur Verfügung stellen. Die externe Hardware läßt nicht zu, daß 
die Unterbrechung die CPU erreicht, außer ihre Priorität ist höher als der Inhalt 
des Prioritätsregisters. Ein Prioritäte-Unterbrechungssystem kann einen spe¬ 
ziellen Weg für die Verarbeitung von Unterbrechungen mit niedriger Priorität 
erfordern, die während längerer Zeltperloden Ignoriert werden können. 


Die meisten Unterbrechungs-Systeme können 
freigegeben oder gesperrt werden. In der Tat 
sperren die meisten CPUs automatisch Unter¬ 
brechungen, wenn ein RESEr ausgeführt wird 

(so daß der Programmierer das Unterbrechungs-System konliguneren kann) 
und bei der Annahme einer Unterbrechung (so daß die Unterbrechung nicht 
durch ihre eigene Unterbrechungs-Routine unterbrochen wird). Der Program¬ 
mierer kann auch den Wunsch haben, Unterbrechungen zu sperren, während er 
Daten vorbereitet oder verarbeitet, eine Zeit-Steuerschleife ausführt oder eine 
Mehr-Wort-Operation vollzieht. 


FREIGABE UND 
SPERRUNG VON 
UNTERBRECHUNGEN 


Eine Unterbrechung, die nicht gesperrt werden 
kann (manchmal auch eine "nicht-maskierbare 
Unterbrechung" genannt), kann sehr nützlich 
sein, bei einem Betriebsspannungs-Ausfall zu 
warnen, ein Vorgang, der offensichtlich Vorrang 
vor allen anderen Aktivitäten besitzen muß. 


Die Vorteile von Unterbrechungen sind offen¬ 
sichtlich, es gibt jedoch auch Nachteile. Diese 
sind: 

1) Unterbrechungs-Systeme können einen beträchtlichen Teil zusätzlicher 
Hardware benötigen. 

2) Unterbrechungen benötigen noch Datentransfers unter der Programmsteue¬ 
rung durch die CPU. Sie besitzt keine Geschwindigkeits-Vorteile wie etwa 
beim DMA. 

3) Unterbrechungen sind zufällige Eingaben, die möglicherweise schwierig zu 
testen und fehlerfrei zu machen sind. Fehler können sporadisch auftreten 
und daher sehr schwer zu finden sein. 2 

4) Unterbrechungen können einen beträchtlichen Aufwand erfordern, wenn 
zahlreiche Register-Inhalte aufbewahrt werden müssen und die Quelle 
durch Abfragen bestimmt werden muß. 


NACHTEILE VON 
UNTERBRECHUNGEN 


NICHT-MASKIERBARE 

UNTERBRECHUNG 
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6502-Unterbrechungs-System 

Die interne Reaktion des 6502 auf eine Unterbrechung ist etwas komplex. Das 
Unterbrechungs-System besteht aus: 


1) Ein maskierbarer Unterbrechungs-Eingang 
(IRQ) mit aktive Low und ein ni cht-m askier- 
barer Unterbrechungs-Eingang (NMi) mit ak¬ 
tiv Low. 

2) Ein Unterbrechungs-Sperr- (oder Masken-) Brt, das die maskierbare Unter¬ 
brechung sperrt. Wenn das Unlerbrechungs-Sperrbit 1 ist, sind keine mas¬ 
kierbare Unterbrechungen erlaubt. 

Das I-Bit wird in Bit 2 des Prozessor-Status- (oder P-) Registers gespei¬ 
chert. 


Der 6502 prüft den momentanen Status des Un¬ 
terbrechungs-Systems am Ende jedes Befehls. 

Wenn eine Unterbrechung aktiv und freigegeben 
ist, so ist die Reaktion folgende: 

1) Die CPU bewahrt den Befehlszähler (höchstwertige Bits zuerst) und das 

Statusregister im Stapel auf. Bild 1 2-1 zeigt die Reihenfolge, in der diese 
Register aufgewahrt werden. Beachten Sie, daß der Akkumulator und die In¬ 
dexregister nicht automatisch gespeichert werden._ 

2) Die CPU sperrt die maskierbare Unterbrechung (IRQ). Das heißt, sie setzt 
Bit 2 (I) des Statusregisters. 

3} Die CPU holt eine Adresse von einem spezifizierten Paar von Speicher¬ 
adressen und legt diese Adresse in den Befehlszähler. Tabelle 12-1 enthält 
die Adressenpaare, die den verschiedenen Eingängen und dem Break-Be¬ 
fehl zugeordnet sind. 


Beachten Sie die folgenden speziellen Eigen¬ 
schaften des Unterbrechungs-Systems des 6502: 

1) Der 6502 bewahr: automatisch den Befehls¬ 
zähler und das Statusregister im Stapel auf. 

Erinnern Sie sich daran, daß das Statusregi¬ 
ster das Unterbrechungsfreigabe-Flag und 
das Break-Kommando-Flag beinhaltet. 

2) Der 6502 liefert keine externen Signale zur Anzeige, daß er eine Unterbre¬ 
chung angenommen hat mit Ausnahme der Adressen, die er auf den Adres¬ 
senbus plaziert. 

3) Der 6502 besitzt keine speziellen internen Vorkehrungen, um die Quelle 
einer Unterbrechung zu bestimmen, wenn es mehrere Quellen gibt, die zum 
gleichen Eingang geführt werden. 

Der 6502 besitzt die folgenden speziellen Befehle, um sein Unterbrechungs- 

System zu handhaben: 

1) CU (Ciear Interrupt Dlsable Bit) löscht Bit 2 des Statusregisters und gibt 
daher die maskierbare Unterbrechung frei. 

2) SEI (Set Interrupt Dlsable Bit) setzt Bit 2 des Statusregisters und sperrt da¬ 
her die maskierbare Unterbrechung. 

3) BRK (Force Break) setzt das Break-Kommandoflag, bewahrt den Befehls¬ 
zähler und das Statusregister im Stapel auf, sperrt die maskierbare Unter¬ 
brechung und plaziert den Inhalt der Adressen FFFE und FFFF in den Be¬ 
fehlszähler. 


SPEZIELLE 
EIGENSCHAFTEN 
DES 6502- 
UNTERBRECHUNGS¬ 
SYSTEMS 


REAKTION DES 6502 
AUF 

UNTERBRECHUNGEN 


6502 

UNTERBRECHUNGS¬ 

EINGÄNGE 


4) RTI (Return from Interrupt) speichert das Statusregister und den Befehls¬ 
zähler vom Stapel zurück. Das Ergebnis ist, daß die alten Werte in den Be¬ 
fehlszähler und in das Statusregister zurückgelegt werden (einschließlich 
des Unterbrechungs Bits). RTI unterscheidet sich von RTS (Return 
from Subroutine) darin, daß RTI sowohl das Statusregister wie auch den 
Befehlszähler zurückspeichert und RTI nicht 1 zur Rückkehr-Adresse 
addiert, wie dies RTS ausführt (siehe Kapitel 11 für eine Besprechung von 
RTS). 


Vorher 


Nachher 



Stapel- 

zeiger 



Stapel¬ 

zeiger 


ss - ursprünglicher Inhalt des Stapelzeigors 
DP- ursprünglicher Inhall des Status-Registers (P) 

PCH - ursprünglicher Inhalt der 8 höherwertigen Bits des Befehlszählers 
PCL - ursprünglicher Inhalt der B niederwertigen Bits des Befehlszählers 


Bild 12-1. Aufbewahren des Status des Mikroprozessors im Stapel. 


Tabelle 12-1. Speicherplan der 6502-Adressen, die zur Reaktion auf 
Unterbrechungen und Reset verwendet werden. 


Quelle 

Verwendete Adressen (Hexadezimal) 

Unierbrechungs-Anlorderung (IRQ) und BRK-Belehl 

FFFE und FFFF 

Reset (RESET] 

FFFC und FFFD 

N cht-maskierbare Unterbrechung (NMI) 

FFFA und FFFB 

Die Adressen werden aul die gebräuchliche Art des 6502 gespeichert, mit den niedrigstwertigen 

Bits m der niedrigen Adresse 

■_ 1 


Der Befehl BRK (Force Break) erzeugt nahezu genalLdje 
gleiche Reaktion wie ein Unterbrechungs-Eingang (IRQ). 

Der einzige Unterschied besteht darin, daB das Break- 
Kommandoflag (Bit 4 des Statusregisters) gesetzt wird. Daher kann eine Ser¬ 
vice-Routine zwischen einem BRK-Befehl und einem IRQ-Eingang unterschei¬ 
den, indem sie Bit 4 des obersten Byte im Stapel prüft (erinnern Sie sich an 
Bild 12-1) Ein typisches Programm wäre: 

PLA ;HOLE STATUSREGISTER VOM STAPEL 

AND #%00010000 ;IST BREAK-KOMMANDOFLAG GESETZT? 

BNE BREAK ;JA, GEHE ZUR BREAK-ROUTINE 


BRK- 

BEFEHL 
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Der BRK-Befehl ist sehr nützlich bei der Fehlersuche (siehe Kapitel 14) und zur 
Rückgabe der Steuerung zu einem Monitor oder Betriebssystem. Siehe Kapi¬ 
tel 3 für weitere Informationen über den BRK-Befehl. 


Die nicht-maskierbare Unterbrechung ist ein 
flanken-sensitiver Eingang. Der Prozessor rea¬ 
giert daher nur auf die Flanke eines Impulses auf 
dieser Leitung, und der Impuls wird seine eigene Unterbrechungs-Routine nicht 
unterbrechen. Nicht-maskierbare Unterbrechungen sind sehr nützlich bei An¬ 
wendungen, die auf den Ausfall der Stromversorgung reagieren müssen (d.h. 
sie müssen Daten in einen Speicher mit niedriger Leistungsaufnahme retten 
oder eine Reserve-Batterie zuschalten). Typische Anwendungen sind Kommuni¬ 
kationsgerate, die Codes aufbewahren müssen und Teil-Mitteilungen, sowie 
Testgeräte, die teilweise abgeschlossene Tests verfolgen müssen. Wir werden 
die nicht-maskierbare Unterbrechung nicht weiter besprechen. Wir wollen an¬ 
nehmen, daß alle Unterbrechungs-Eingaben zu IRQ geführt wird. 


NICHT-MASKIERBARE 

UNTERBRECHUNG 


6520-PIA-Unterbrechungen 3 


Die meisten Unterbrechungssysteme des 6502 
beinhalten programmierbare Interface-Chips 
oder Mehrfunktions-Bausteine, wie den 6520 Pe¬ 
ripherer Interface Adapter, 6522 Versatile Interface-Adapter oder die Mehrfunk¬ 
tions-Bausteine 6530 und 6532 Jede Seite des PIA 6520 besitzt folgende 
Eigenschaften zur Verwendung bei Unterbrechungen: 

1) Einen Unterbrechungs-Eingang mit aktiv Low. 

2) Unterbrechungs-Freigabe-Bits (Bit 0 des Steuer-Registers für die Steuerlei¬ 
tung 1, Bit 3 für die Steuerleitung 2). 

3) Unterbrechungs-Status-Bits (Bit 7 des Steuer-Registers für die Steuerlei¬ 
tung 1, Bit 6 für die Steuerleitung 2) 

Die Bits t und 4 des Steuer-Registers bestimmen, ob eine ansteigende Flanke 
(Übergang Low auf High) oder eine Riickflanke (Übergang High auf Low) auf 
der Steuerleitung eine Unterbrechung verursacht. 

Beachten Sie, daß: 

1) Die PIA-Unterbrechungs-Freigabebits die entgegengesetzte Polarität des 
I-Flags des 6502 besitzen, d.h., sie müssen "1" sein, um eine Unterbre- 
chuoa freizuaeben. 

2) RESET löscht die PIA-Steuerregister und sperrt daher alle Unterbrechun¬ 
gen. 

3) Die CPU kann die Bits 6 und 7 des Steuerregisters prüfen um festzustel¬ 
len, ob ein PIA eine Unterbrechung bereit hat. Sobald gesetzt, bleiben die¬ 
se Bits in diesem Zustand, bis die CPU die PIA-Datenregister liest. 

4) Der PIA wird sich an eine Unterbrechung erinnern, die auf tritt, während 
PIA-Unterbrechungen gesperrt waren, und wird eine Unterbrechungs-An¬ 
forderung liefern, sobald die PIA-Unterbrechung freigegeben wird. 


6520-PIA- 

UNTERBRECHUNGEN 


6522-VIA-UNTERBRECHUNGEN 


Der 6522 Versatile Interface-Adapter (Vielseiti¬ 
ger Interface-Adapter) kann auch als Unterbre¬ 
chungsquelle verwendet werden. Dieser Bau¬ 
stein besitzt ein Unterbrechungs-Freigaberegister (Interrupt Enable Register = 
IER), das zur Freigabe der verschiedenen Unterbrechungsquellen verwendet 
werden kann, und ein Unterbrechungsflag-Register (IFR = Interrupt Flag Regi¬ 
ster), das den Status der verschiedenen Quellen enthält. Bild 12-2 zeigt die Po¬ 
sitionen der verschiedenen Freigabe-Bits im Unterbiechungs-Freigaberegister, 
und Bild 12-3 beschreibt das Unterbrechungsflag-Register. 


Eine Unterbrechungsquelle kann freigegeben 
werden, indem die entsprechenden Freigabe- 
Bits gesetzt werden. Beachten Sie, daß das 
höchstwertige Bit kontrolliert, wie die anderen 
Freigabe-Bits beeinflußt werden. 

1) Wenn IER7- 0, löscht jede 1 in einer Bit-Position ein Freigabe-Bit und sperrt 
daher die Unterbrechung. 

2) Wenn IER7 = 1, setzt jede 1 in einer Bit-Position ein Unterbrechungsbit 
und gibt daher diese Unterbrechung frei. 

Nullen in den Freigabe-Bit-Positionen lassen die Freigabe-Bits unverändert 

Einige Beispiele für Freigabe und Sperren der 6522-VIA Unterbrechungen 
sind: 

1) Gib CAI-Unterbrechung frei, sperre alle übrigen: 

LDA #%01111101 ;SPERRE ALLE ÜBRIGEN 
; UNTERBRECHUNGEN 

STA VIAIER 

LDA #%1 0000010 ;GIB CAI-UNTERBRECHUNG FREI 
STA VIAIER 

Die erste Operation setzt IER7 auf null, so daß die Einsen in den Bit-Positionen 
0, 2, 3, 4, 5 und 6 die entsprechenden Freigabe-Bits löschen und daher diese 
Unterbrechungen sperren. Die zweite Operation setzt IER7 auf 1, so daß die 1 
in Bit-Position 1 das entsprechende Freigabe-Bit (CAI-Unterbrechung) setzt 
und daher diese Unterbrechung freigibt. 

2) Gib CB1- und CB2-Unterbrechungen frei, sperre alle übrigen. 

LDA #%01100111 ;SPERRE ALLE ÜBRIGEN 
; UNTERBRECHUNGEN 

STA VIAIER 

LDA #%1 0011 000 ;GIB CB1-, CB2-UNTERBRECHUNGEN FREI 
STA VIAIER 

Die erste Operation setzt IER7 auf 0, so daß die Einsen in den Bit-Positionen 0, 
1, 2, 5 und 6 die entsprechenden Freigabe-Bits löschen und daher diese Un¬ 
terbrechungen sperren. Die zweite Operation setzt IER7 auf 1. so daß die Ein¬ 
sen in den Bit-Positionen 3 und 4 die entsprechenden Freigabe-Bits (Bit 3 für 
CB2, Bit 4 für CB1) setzen und daher diese Unterbrechungen freigeben. 


FREIGABE UND 
SPERREN DER 
UNTERBRECHUNGEN 
DES 6522 VIA 


6522-VIA- 

UNTERBRECHUNGEN 
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Neben den in Bild 12-3 beschriebenen Bedingungen können die Bits im Unter¬ 
brechungsflag-Register auch durch Schreiben von Einsen in die eiforderlichen 
Bit-Positionen an der entsprechenden Adresse gelöscht werden. Dieses Ver¬ 
fahren ist sehr nützlich für das Löschen von Flags, die in den unabhängigen Be¬ 
triebsarten verwendet werden, und zum Eliminieren unerwünschter Unterbre¬ 
chungen, die zufällig während des Reset- oder Start-Vorganges verursacht wer¬ 
den könnten. Beachten Sie, daß die Bit-Positionen des Unterbrechungsflag- 
Registers die gleichen sind, wie die Bit-Positionen des Unterbrechungsfreigabe- 
Registers, so daß wir die vorhergehenden Beispiele leicht zum Eliminieren be¬ 
stimmter Unterbrechungen erweitern können. Dies kann entweder durch Freiga¬ 
be- oder Sperr-Operationen geschehen, da der Wert von Bit 7 keine Rolle spielt. 
Die erweiterten Beispiele sind: 

1) Gib CAI-Unterbrechungen frei, sperre alle übrigen, lösche CAI-Unterbre- 
chungs-Flag. 


LDA 

#%01111101 

;SPERRE ALLE ÜBRIGEN 
; UNTERBRECHUNGEN 

STA 

VIAIER 


LDA 

#%10000010 


STA 

VIAIFR 

;LÖSCHE CA1-UNTERBRECHUNGSFLAG 

STA 

VIAIER 

;GIB CA1-UNTERBRECHUNG FREI 


7 

6 

5 

4 

3 

2 

1 

0 - 

Setz/ 

Lösch 

Steue¬ 

rung 

TI 

E 

J CB1 

CB2 

SR 

J CA1 

El 


_ Unte brechungs-Freigabe- 
Register 


Siehe Bild 12-3 für die Bedeutung der Unterbrechungs- 
Bezeichnungen. 

Bit 7 wird ausführlich im Haupttext bes hneben. 


“ Festgelegte Unteibrechungs-Frfligabfl 
1 - Unterbrechung freigegeben 
0 - Unterbrechung gesperrt 
-Setze der lösche Bits 0-6 
1 - Schreiben von 1 setzt BitauH 
0- Schreiben von i setzt Bit auf 0 
Schreiben von 0 zu einem der Bits 
0-6 hat keinen Einfluß ■ 


Bild 12-2. Beschreibung der Unterbrechungs-Freigabe Register des VIA 6522. 


2) Gib CB1- und CB2-Unterbrechung frei, sperre alle übrigen, lösche CB1- 
und CB2-Flags. 

LDA #%01100111 .SPERRE ALLE ÜBRIGEN 
; UNTERBRECHUNGEN 

STA VIAIER 
LDA #%10011000 

STA VIA1FR ;LÖSCHE CB1 , CB2- UNTERBRECHUNGS- 

; FLAGS 

STA VIAIER ;GIB CB1-. CB2-UNTERBRECHUNGEN FREI 

Beachten Sie, daß Bit 7 des Unterbrechungsflag-Registers und Bit 7 des Un¬ 
terbrechungsfreigabe-Registers beide sehr spe ziell sind. BTt 7 des Unterbre¬ 
chungsflag-Registers zeigt den Status des IRO-Ausganges an - das heißt, es 
ist 1, wenn irgendeine der Unterbrechungen sowohl aktiv wie freigegeben ist. Bit 
7 des Unterbrechungsfreigabe-Registers ist die Setz/Lösch-Steuerung, die 
früher erwähnt wurde Beachten Sie, daß Bit 7 des Unterbrechungsflag- 


12-8 


Registers nicht direkt gelöscht werden kann. Es kann nur entweder durch 
Löschen aller aktiven Unterbrechungs-Flags oder durch Sperren aller aktiven 
Unterbrechungen gelöscht werden. 


1 6 5 4 3 2 1 0 

IRQ TI I T2 CB1 I CB2 SR CA1 I CA2 


Bit-Nummer 

■ UntertxecfHmga-Flag-Register 


Bit 7 zeigt den Status des IRO-Ausgangsan. Dieses Bit entspricht der folgenden Logik-Funktion: 

IRO - HFR6 A IER6) V <iFR5 \ IER5I V IFR4 A (EH4) V <IFR3 A IER3I V 0FR2 A IER2) V IlFHI A IER11 V 
HFRO A lEROI 

Oie BitsO- 6 sind 2wis henspeicher. die wie folgt ge setzt undgekjschl werden: 


Gesetzt durch 

Aktiver Übergang Oes Signals 
am Pin CA2 


Aktiver Übergang Oes Signals 
am Pin CA1 


Gelöscht durch 

Lesen oder Schreiben des 
A-Port-Ausgangsregisler {ORA) unter 
Verwendung der Adresse 0001 

Lesen oder Schreiben des 

A-Port-Ausgangs reg Islers (ORA) unler 

Verwendung der Adresse 0001 


2 

Abschluß von acht 
Verschiebungen 

Lesen oder Schreiben des 

Schieberegisters 

3 

Aktiver Übergang Oes Signals 
am Pin CB2 

Lesen oder Schreiben des 
ß-Porl-Ausgangsregislers 

D 

Akliver Übergang Oes Signals 
am Pin CB1 

Lesen oder Schreiben des 
ß-Porl-Ausgangsregisters 

5 

Ablaut von Zeitgeber 2 

Lesen des niederwertigen Zählers von T2 oder 
Schreiben des hochwertigen Zählers von T2 

6 

Ablauf von Zeitgeber 1 

Lesen des niederwertigen Zählers von TI oder 
Schreiben des hochwertigen Zwischenspeichers 
von T2 


Bild 12-3. Beschreibung des Unterbrechungs-Flag Registers des VIA 6522. 

Beachten Sie folgendes über VIA-Unterbrechungen: 


1) Die VIA-Unterbrechungs-Freigabebits haben die entgegengesetzte Polari¬ 
tät des I- (oder Unterbrechungssperr-) Flags der 6502. Das heißt, sie müs- 
sen 1 s ein, um eine Unterbrechung freizugeben. 

2) RESET sperrt alle Unterbrechungen. 

3) Die CPU kann Bit 7 des Unterbrechungsflag-Registers prüfen um festzu¬ 
stellen, ob Irgendwelche Unterbrechungen sowohl aktiv wie freigegeben 

sind. Dieses Bit wird gesetzt bleiben, bis keine Unterbrechung sowohl aktiv 
wie freigegeben ist. 

4) Der VIA wird sich an eine Unterbrechung erinnern, die auftritt, w ann VIA- 
Unterbrechungen gesperrt sind, und wird eine Anforderung über IRO aus¬ 
geben, wenn der VIA freigegeben wird. 

Über VIA-Unterbrechungen werden mehrere Beispiele später in diesem Kapitel 
behandelt. 
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Unterbrechungen mit Mehrfunktions- 
Bausteinen 6530 und 6532 


Der Baustein 6530 kann eine Unterbrec hung 
von seinem Intervall-Zeitgeber liefern. Der IRQ- 
Ausgang ist auch Anschluß PB7 von Port B und 
sollte als Eingang eingerichtet werden, wenn er 
zur Auslösung einer Unterbrechung verwendet 
wird. Die Unterbrechung kann durch Einschreiben in den Zeitgeber freigegeben 
werden, wobei die Adressenleitung A3 High ist. Die Unterbrechung kann ge¬ 
sperrt werden, indem zum Zeitgeber mit Low auf der Adressenleitung A3 ge¬ 
schrieben wird. Sie kann gelöscht werden, entweder durch Lesen oder durch 
Schreibendes Zeitgebers, nachdem eine Unterbrechung aufgetreten ist. 

Der Baustein 6532 kann eine Zeitgeber-Unterbrechung wie der Baustein 6530 
liefern. Er kann auch eine Unterbrechung liefern, die auf dem Auftreten einer 
Flanke an PA7 basiert. PA7 arbeitet daher ähnlich wie CA1 oder CB1 auf einem 
PIA 6520 oder VIA 6522. Die Unterbrechung kann entweder bei einem Low-zu- 
High-Übergang (positive Flanke) oder einem High-zu-Low-Übergang (negative 
Flanke) auftreten. 

6532-Unterbrechungen werden durch Schreiben zu und Lesen von spezifizier¬ 
ten Adressen gesteuert und geprüft (siehe Tabelle 12-2 für eine Beschreibung 
der Adressen in einem 6532-Baustein). Beachten Sie folgendes: 

1) Zur Steuerung der PA7-Unterbrechung schreiben Sie einfach irgendwelche 
Daten in den E/A-Abschnitt des 6532, gegeben durch: 

RS = 1, um E/A z u aktivieren, anstatt des auf der Platine befindlichen RAM's. 
A2 = 1,A4 = 0 

Die beiden niedrigstwertigen Adressen-Bits (nicht die Daten) steuern dann die 
PA7-Betriebsart wie folgt: 

AI = 1, um die PA7-Unterbrechung freizugeben, 0 um sie zu sperren. 

A0- 1 für eine positive (Low-zu-High) Flanken-Feststellung, 0 für eine nega¬ 
tive (High-zu-Low) Flanke. 

2) Um die Unterbrechungs-Flags zu lesen und zu löschen, lesen Sie von der 
Adresse im E/A-Abschnitt des 6532, gegeben durch: 

RS - 1 zum Aktivieren von E/A, anstatt des auf der Platine befindlichen 
RAM's. 

A2-1, AO - 1 

Bit 7 ist das Zeitgeber-Unterbrechungsflag und Bit 6 das PA7-Unterbrechungs- 
flag. Dies kann leicht mittels des Befehls Bit-Test gelesen werden (Bit 7 wird 
zum Vorzeichen-Flag und Bit 6 zum Überlauf-Flag transferiert). 


ACIA-Unterbrechungen 


Der ACIA 6850 kann ebenfalls als Quelle für Un¬ 
terbrechungen dienen. Sie sollten folgende 
Eigenschaften des ACIA bei einem auf Unterbre¬ 
chungen basierenden System beachten: 

1) Die Sende-Unterbrechung (ACIA ist bereit für Daten) wird nur freigegeben, 
wenn das Steuerregister-Bit 6 = 0 und das Steuerregister-Bit 5=1 ist. 

2) Empfänger-Unterbrechung (ACIA hat neue Daten empfangen) wird nur 
freigegeben, wenn das Steuerregister-Bit 7=1 ist. 

3) Das Haupt-Reset beeinflußt die Unterbrechungs-Freigabe-Bits nicht. 

4) Bit 7 des Statusregisters wird gesetzt, wenn eine Unterbrechung aufgetre¬ 
ten ist. Dieses Bit kann entweder durch Lesen von Daten vom ACIA oder 
durch Schreiben von Daten in den ACIA gelöscht werden. 


Tabelle 12-2. Adressieren des Mehrfunktions-Bausteins 6532. 


Auswahl-Leitungen 

Adressier-Art 

RS 

R/W 

A4 

A3 

A2 

AI 

AO 








RAM-Adressierung 

0 

1(0) 

X 

X 

X 

X 

X 

Lies (Schreib) RAM. AO - A6 wählt RAM-Adresse 








E/A- Adressierung 

1 

1(0) 

X 

X 

0 

0 

0 

Lies (Schreibe) Porl-A-Daten 

1 

1(0) 

X 

X 

0 

0 

1 

Lies (Schreibe) Porl-A-Datenrichtungs-Register 

1 

1(0) 

X 

X 

0 

1 

0 

Lies (Schreibe) Porl-B-Dalen 

1 

1(0) 

X 

X 

0 

1 

1 

Lies (Schreibe) Porl-B-Oalenrichlungs-Register 








Flanken-Feststellungs-Steuerung 

1 

0 

0 

X 

1 

0 

X 

Sperre Unterbrechung von PA7 

1 

0 

0 

X 

1 

1 

X 

Gib Unterbrechung von PA7 frei 

1 

0 

0 

X 

1 

X 

0 

Feststellung der negativen Flanke 

1 

0 

0 

X 

1 

X 

1 

Feststellung der positiven Flanke 

1 

1 

X 

X 

1 

X 

1 

Liesund lösche Unterbrechungs-Flags 








Bit 7 istdasZeitgeber-Fiag 

Bit 6 «st das PA7-Flag 








Schreibe Zahlung zum Intervall-Zeitgeber 

1 

0 

1 

0 

1 

X 

X 

und sperre Zeilgeber-Unierbrechung 

1 

0 

1 

1 

1 

X 

X 

und gib Zeilgeber-Unlerbrechung frei 

1 

0 

1 

X 

1 

0 

0 

und dekrerrentiere bei jedem ^ 2-lmpuls 

1 

0 

1 

X 

1 

0 

1 

unddekremenliere alle 8$ 2-lmpulse 

1 

0 

1 

X 

1 

1 

0 

und dekremenliere alle 64 2-lmpulse 

1 

0 

1 

X 

1 

1 

1 

und dekrementiere alle 1024 0 2-lmpulse 


Für alle Operationen CS1 - 1. CS2 - 0. 

Logik-Pegel: 0 bedeulel Low-Pegel 
1 bedeulel High-Pegel 

X bedeulel, daß der Pegel dieses Signals ohne Bedeutung ist (eniweder 0 oder t) 


6530 UND 6532 
MEHRFUNKTIONS¬ 
BAUSTEIN¬ 
UNTERBRECHUNGEN 


6850-ACIA- 

UNTERBRECHUNGEN 
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6502-Abfrage-Unterbrechungssysteme 

Die meisten Unteit>rechungs-Systeme des 6502 ABFRAGE- 
müssen entweder den PIA, VIA, ACIA oder an- UNTERBRECHUNGEN 
dere Bausteine abfragen um zu bestimmen, wel¬ 
cher eine Unterbrechung bewirkt hat. Die Abfra¬ 
ge- (Polling-) Methode lautet: 

1) Teste jeden PIA durch Prüfen der Steuerregister-Bits 6 und 7: 

BIT PIACR ;PRÜFE PIA-STATUSBITS 

BMI INT1 ;VERZWEIGE ZUR UNTERBRECHUNG 1, 

; WENN BIT 7 GESETZT 

BVS INT2 ;VERZWEIGE ZU UNTERBRECHUNG 2, 

; WENN BIT 6 GESETZT 

2) Teste jeden VIA durch Prüfen des Unterbrechungsflag-Register-Bit 7: 

BIT VIAFR ;SIND IRGENDWELCHE UNTERBRECHUN- 

; GEN AN DIESEM VIA AKTIV? 

BMI INTV ;JA, PRÜFE ALLE FLAGREGISTER 

Sie müssen noch das Unterbrechungsflag-Register prüfen, wenn es mehr als 
eine mögliche Unterbrechungsquelle von einem speziellen VIA gibt. Alles, was 
Ihnen Bit 7 sagt, besteht darin, daß es wenigstens eine Quelle gibt, die sowohl 
aktiv wie freigegeben ist. 

3) Teste jeden ACIA durch Prüfen des Statusregister-Bits 7: 

BIT ACIASR ;SIND IRGENDWELCHE UNTERBRECHUN- 

. GEN AKTIV IN DIESEM ACIA? 

BMI INTA JA, BESTIMME WELCHE ERFORDERLICH IST 

Die Unterbrechung könnte noch entweder eine Empfänger- oder Sende-Unter- 
brechung sein. 

Die wichtigsten Eigenschaften eines Abfrage-Systems des 6502 sind: 

1) Die erste geprüfte Unterbrechung besitzt die höchste Priorität, da die ver¬ 
bleibenden Unterbrechungen nicht geprüft werden, wenn die erste aktiv 

ist. Die zweite Unterbrechung besitzt die nächsthöhere Priorität usw. 

2) Die Service-Routine muß die Unterbrechungs-Flags von den PIAs, VIAs, 
ACIAs oder anderen Bausteinen löschen, wenn dieses Löschen nicht auto¬ 
matisch ausgeführt wird. 
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Der Programmierer sollte besonders sorgfältig sein bei: 

- Verwendung von PIAs als Unterbrechungs-Ausgabepoits. 

Ein "Dummy Read" des Ports ist erforderlich, da das Unterbrechungs-Flag 
nicht automatisch gelöscht wird, wenn Daten in den Port geschrieben werden. 
PIA-Status- (Unterbrechungs-) Flags werden nur gelöscht, wenn die Datenre¬ 
gister gelesen werden. 

- Verwendung von VIAs in der unabhängigen Betriebsart oder über Adressen, 
die die Unterbrechungs-Fiags nicht beeinflussen. 

Das Unterbrechungs-Fiag muß dann ausdrücklich gelöscht werden, indem eine 
logische 1 in das entsprechende Bit des Unterbrechungsffag-Registers ge¬ 
schrieben wird, 

Abfrage-Routinen sind ausreichend, wenn es NACHTEILE DER 
nur einige Eingänge gibt. Sind jedoch mehrere ABFRAGE- 
Eingänge vorhanden, so sind die Abfrage-Routi- UNTERBRECHUNGEN 
nen langsam und mühsam aus folgenden Grün¬ 
den: 

1) Die durchschnittliche Anzahl der Abfrage-Operationen steigt linear mit der 
Anzahl der Eingänge. Im Durchschnitt wird man natürlich nur die Hälfte der 
Eingänge abzufragen haben, bevor man den richtigen findet. Man kann die 
durchschnittliche Anzahl der Abfrage-Operationen etwas verringern, indem 
man die am häufigsten verwendeten Eingänge zuerst prüft 

2) PIA-, VIA- und ACfA-Adressen sind selten aufeinanderfolgend oder im glei¬ 
chen Abstand. Daher sind separate Befehle erforderlich, um jeden Eingang 
zu prüfen. Abfrage-Routinen sind deshalb schwierig zu erweitern. Tabelle 
von E/A-Adressen könnten durch Plazieren der Basis-Adresse auf Seite Null 
verwendet werden, sowie durch Verwendung der nach-indizierten Adressie¬ 
rung durch Plazieren der gesamten Tabelle auf Seite Null und Verwendung 
der vor-indizierten Adressierung. 

3) Unterbrechungen, die zuerst abgefragt werden, können jene sperren, die 
später abgetragt werden, außer die Reihenfolge der Abfrage wird variiert. 
Jedoch das Fehlen aufeinanderfolgender Adressen macht ein Variieren der 
Reihenfolge der Abfrage sehr schwierig. 


Vektorisierte Unterbrechungs- 
Systeme mit dem 6502 

Das Problem des Abfragens in Systemen mit 6502 
dem 6502 wurde durch spezielle Verfahren für VEKTORISIERTE 
bestimmte Anwendungen oder Mikrocomputer UNTERBRECHUNGEN 
gelöst. Beachten Sie, daß es keinen Weg gibt 

um festzustellen, daß der 6502 eine Unterbrechung angenommen hat, außer 
durch Beobachten, wann die Adressen FFFE und FFFF auf dem Adressenbus 
aufscheinen. Spezielle Hardware kann dann den Vektor ersetzen, der durch 
die tatsächliche Quelle geliefert wird 4 . Wir wollen das vektorisierte Unterbre¬ 
chungs-System des 6502 nicht weiter besprechen. 
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BEISPIELE 

Eine Start-Unterbrechung 

Zwack: Der Compuler wartet auf das Auftreten einer VIA-Unterbrechung, bevor 
er mit tatsächlichen Operationen beginnt. 


Zahlreiche Systeme verbleiben inaktiv, bis sie der Bedienende tatsächlich Star 
tet oder ein DATA-READY-Signal empfangen wird. Bei RESET müssen derartige 
Systeme den Stapelzeiger initialisieren, die Start-Unterbrechung freigeben und 
eine endlose Schleife oder Jump-lo-self-Befehl ausführen. Erinnern Sie sich da¬ 
ran daß RESET die Prozessor-Unterbrechung sperrt (indem I auf 1 gesetzt wird) 
sowie alle VIA-Unterbrechungen (durch Löschen alter VtA-Unterbrechungs^Frei- 
□abe-Bits) Im Flußdiagramm ist die Entscheidung, ob der Start aktiv ist, durch 
die Hardware ausgeführt (d.h., indem die CPU den Unterbrechungs-Eingang in¬ 
tern prüft) anstatt durch Software. 


Flußdiagramm: 


Quellprogramm: 



Hauptprogramm: 

LDX 

TXS 

LDA 

STA 

LDA 

STA 

STA 

CLI 

HERE JMP 


#$FF 

#0 

VIAPCR 

#%10000010 

VIAIFR 

VIAIFR 

HERE 


;LEGE STAPEL AN DAS ENDE VON SEITE 1 


;MACHE ALLE STEUERLEITUNGEN ZU 
; EINGÄNGEN 

tLÖSCHE CA1 -UNTERBRECHUNGSFLAG 
;GIB CA1 UNTERBRECHUNG FREI 
;GIB CPU-UNTERBRECHUNG FREI 
;WARTE WEITER 


Unterbrechungs-Seivice-Rouline: 

•-INTRP 

LDA #%10000010 

STA VIAIFR ;LOSCHE CA1-UNTERBRECHUNGSFLAG 

LDX #$FF :REINITIALISIERE STAPELZEIGER 

TXS 

JMP START 
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Objektprogramm: 


Speicher-Adresse Speicher-Inhalt Befehl 


(Hex) 

(Hex) 


(Mnemonik) 

Hauplprogramm: 





0000 

A2 


LDX 

#$FF 

0001 

FF 




0002 

9A 


TXS 


0003 

A9 


LDA 

#0 

0004 

00 




0005 

BD 


STA 

VIAPCR 

0006) 

00071 

VIAPCR 




0000 

A9 


LDA 

#%10000010 

0009 

02 




OOOA 

BD 


STA 

VIAIFR 

00001 

ooocf 

VIAIFR 




000D 

BD 


STA 

VIAIER 

000EI 

000F1 

VIAIER 




0010 

50 


CU 


0011 

4C 

HERE 

JMP 

HERE 

0012 

11 




0013 

00 




Unterbrechungs-Service-Routine: 




INTRP 

A9 


LDA 

#%10000010 

INTRP+1 

02 




INTRP+2 

0D 


STA 

VIAIFR 

INTRP+31 

INTRP+4) 

VIAIFR 




INTRP+5 

A2 


LDX 

#$FF 

INTRP+6 

FF 




INTRP+7 

9A 


TXS 


INTRP+8 

4C 


JMP 

START 

INTRP+9) 

INTRP+Al 

START 
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Die genaue Lage der Unterbrechungs-Service- 
Rouline variiert mit dem Mikrocomputer. Wenn 
Ihr Mikrocomputer keinen Monitor besitzt, kann 
man eine beliebige Adresse in die Speicherplät¬ 
ze FFFE und FFFF plazieren (oder Speicherplätze, die diesen Adressen entspre¬ 
chen). Man muß dann die Unterbrechungs-Routine an den Adressen starten, die 
man auswählt. Natürlich sollten Sie die Routine so plazieren, daß sie nicht feste 
Adressen oder andere Programme stört. 


Wenn Ihr Mikrocomputer-System ein Monitorpro¬ 
gramm besitzt, so wird der Monitor die Adressen 
FFFE und FFFF belegen. Diese Adressen werden 
entweder eine Start-Adresse enthalten, in die Sie 
Ihre Unterbrechungs-Service-Routine plazieren müssen, oder sie werden die 
Start Adresse einer Routine enthalten, die Ihnen die Wahl der Start-Adresse der 
Unterbrechungs-Routine gestattet Eine typische Monitor-Routine wäre: 

MONINT JMP (USRINT) [SPRINGE ZU ANWENDER-ADRESSE FÜR 

; UNTERBRECHUNG 

Sie müssen dann die Adresse Ihrer Service Routine in die Speicherplätze 
USRINT und USRINT+1 plazieren. Erinnern Sie sich daran, daß MONINT eine 
Adresse im Monitorprogramm ist und ihr Wert in den Adressen FFFE und FFFF 
liegt. 

Sie können das Laden der Speicherplätze USRINT und USRINT+1 in Ihr Haupt¬ 
programm einschließen: 

LDA #USRL ;LADELSB'SDER ANWENDER-UNTER- 

; BRECHUNGSADRESSE 

STA USRINT 

LDA #USRM ;LADEMSB’SDER ANWENDER-UNTER- 

; BRECHUNGSADRESSE 

STA USRINT+1 

Diese Belehle müssender Freigabe der Unterbrechungen vorausgehen. 

Das Hauptprogramm gibt nur die Unterbrechung vom Start-VIA frei. Wir haben 
angenommen, daß die Startleitung mit dem Eingang CA1 des VIA verbunden ist 
und daß die aktive Flanke die abfallende ist (d.h. ein High-zu-Low-Übergang). 
Andere Konfigurationen würden einfach andere Werte im VIA-Peripherie-Steuer- 
register erfordern. 

Beachten Sie, daß die VIA-Unterbrechung freigegeben und der Stapelzeiger ge¬ 
laden wird, bevor die CPU-Unterbrechung freigegeben wird (durch Löschen des 
I-Bits). Was würde geschehen, wenn Sie das I-Bit vor dem Laden des Stapelzei¬ 
gers löschen würden? Dies wäre jedoch kein wesentliches Problem, wenn der 
Monitor bereits einen Wert in den Stapelzeiger plaziert. 


In diesem Beispiel ist die Rückkehr-Adresse und Statusregister, die der 6502 bei 
Annahme einer Unterbrechung in den Stapel speichert, nicht sehr nützlich. Da¬ 
her reinitialisiert die Service-Routine einfach den Stapelzeiger. 

Beachten Sie, daß wir den Befehl JMP HERE durch eine bedingte Verzweigung 
ersetzen könnten, die einen gesicherten Sprung liefert, wie etwa BNE HERE. 
Das Null-Flag ist nicht null, da die letzte Operation die eine war, die die CA1- 
Unterbrechung freigab. Diese Kurzform ist häufig sehr nützlich infolge der Tatsa¬ 
che, daß der 6502 keinen unbedingten Sprung mit relativer Adressierung be¬ 
sitzt. 


Erinnern STe sich daran, daß RESET und das Annehmen einer Unterbrechung¬ 
automatisch das Unterbrechungssystem sperrt. Dies gestattet der Start-Routi¬ 
ne das Konfigurieren aller VIAs und anderer Unterbrechungsquellen, ohne 
selbst unterbrochen zu werden. Beachten Sie, daß Sie das CAI-Unterbre- 
chungsflag ausdrücklich löschen müssen, oder es würde wieder unterbrechen, 
sobald das Unterbrechungssystem wieder freigegeben wird. Sie könnten auch 
das Flag durch Lesen des VIA-Ausgangsregisters A von der Quittierungs-Adres¬ 
se löschen (siehe Tabelle 11-7). 


UNTERBRECHUNGEN 
BEI SPEZIELLEN 
MIKROCOMPUTERN 


HANDHABUNG VON 
UNTERBRECHUNGEN 
DURCH MONITORE 
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Eine Tastatur-Unterbrechung 

Zweck: Der Computer wartet auf eine Tastatur- 
Unterbrechung und plaziert die Daten 
von der Tastatur in den Speicherplatz 
0040. 


TASTATUR¬ 

UNTERBRECHUNG 


Beispiel: 

Tastatur-Daten = 06 
Ergebnis. (0040) = 06 


FfuBdiagramm: 


Quellprogramm: 



Hauptprogramm: 

LDX 

TXS 

LDA 

STA 

STA 

LDA 

STA 

STA 

CU 

HERE JMP 


iBRINGE STAPEL AN DAS ENDE VON 
; SEITEI 


#0 

VIAPCR 

VIADDRA 


MACHE ALLE STEUERLEITUNGEN ZU 
; EINGÄNGEN 

MACHE PORT-A-LEITUNGEN ZU 
; EINGÄNGEN 


#%10000010 

VIAIFR 

VIAIER 


HERE 


LÖSCHE TASTATUR-UNTERBRECHUNGS- 

GIBTASTATUR-UNTERBRECHUNG VON VIA 
, FREI 

;GIB CPU-UNTERBRECHUNG FREI 
: "DUMMY"-HAUPTPROGRAMM 


Unterbrechungs-Service-Routine: 

*=INTRP 

r ' LJA BEWAHRE AKKUMULATOR IM STAPEL AUF 

HOLE TASTATUR-DATEN 
BEWAHRE TASTATUR-DATEN AUF 
SPEICHERE AKKUMULATOR VON STAPEL 
ZURÜCK 
RTI 

Objektprogramm: 


LDA VIAORA 
STA $40 
PLA 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 


Befehl 

(Mnemonik) 

Hauptprogramm: 





ooou 

A2 


LDX 

#$FF 

0001 

FF 




0002 

9A 


TXS 


0003 

A9 


LDA 

#0 

0004 

00 




0005 

8D 


STA 

VIAPCR 

00061 

00071 

VIAPCR 




0008 

9D 


STA 

VIADDRA 

00091 

OOOAi 

VIADDRA 




0008 

A9 


LDA 

#%10000010 

OOOC 

82 




OOOD 

9D 


STA 

VIAIFR 

OOOEl 

000F1 

VIAIFR 




0010 

80 


STA 

VIAIER 

00111 

00121 

VIAIER 




0013 

58 


CLI 


0014 

4C 

HERE 

JMP 

HERE 

0015 

14 




0016 

00 




Unterbrechungs-Service-Routine: 




INTRP 

48 


PHA 


INTRP+1 

AD 


LDA 

VIAORA 

INTRP+21 

INTRP+31 

VIAORA 




INTRP+4 

85 


STA 

$40 

INTRP+5 

40 




INTRP+6 

68 


PLA 


INTRP+7 

40 


RTI 
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Sie müssen den VIA vollständig vor der Freigabe der Unterbrechungen konfigu¬ 
rieren. Dies beinhaltet das Einrichten der Richtungen der Ports. Bestimmen der 
Übergänge, die auf den Tastleitungen erkannt werden müssen, und die Freigabe 
von Zwischenspeichern (erinnern Sie sich daran, daß das Setzen von Bit 0 des 
Flilfs-Steuerregisters den Zwischenspeicher des Ports A freigibt). 

JMP HERE ist ein Befehl für eine endlose Schleife (Jump-to-self), die zur Dar¬ 
stellung des Hauptprogramms verwendet wird. Nachdem Unterbrechungen in 
einem Arbeitssystem freigegeben wurden, führt das Hauptprogramm seine 
eigentliche Arbeit aus, bis eine Unterbrechung auftritt, und nimmt dann die Aus¬ 
führung nach Abschluß der Unterbrechungs-Service-Routine wiederaut. 


Der RTI-Befehl am Ende der Service-Routine 
transferiert die Steuerung zurück zum JMP-Be- 
fehl im Hauptprogramm. Wenn Sie dies vermei¬ 
den wollen, können Sie einfach den Befehlszäh¬ 
ler im Stapel ändern. Erinnern Sie sich daran, daß 
der Stapel immer auf Seite 1 (Adressen 0100 -01 FF) liegt, der Stapelzeiger die 
Adresse des nächsten leeren Speicherplatzes enthält und die Reaktion auf die 
Unterbrechung den Befehlszähler in den Stapel unterhalb des Stapelregisters 
plaziert. Daher wird das folgende Programm den Befehlszähler im Stapel in- 
krementleren, ohne Ihn hierbei zu entfernen. 

TXS ;MACHE STAPELZEIGER ZU INDEX 

INC $0102,X ;INKREMENTIERE LSB'S DER 

; RÜCKKEHR-ADRESSE 

BNE DONE 

INC $0103,X ;UND ÜBERTRAG ZU MSB'S FALLS 

; ERFORDERLICH 

DONE (nächster Befehl) 

Da der 6502 seine Register nicht automatisch aufbewahrt (anders als das Sta¬ 
tusregister), können Sie ihn zum Übertragen von Parametern und Ergebnissen 
zwischen dem Hauptprogramm und der Unterbrechungs-Service-Routine ver¬ 
wenden. So könnten Sie daher die Daten im Akkumulator lassen, anstatt im 
Speicherplatz 0040. Dies ist jedoch eine gefährliche Praxis, die man vermeiden 
sollte, mit Ausnahme in extrem einfachen Systemen. In den meisten Anwendun¬ 
gen verwendet der Prozessor seine Register während der normalen Programm- 
Ausführung. Wenn nun die Unterbrechungs-Service-Routine zufällig den Inhalt 
dieser Register ändert, gibt es unübersehbare Probleme. Im allgemeinen sollte 
keine Unterbrechungs-Service-Routine jemals irgendwelche Register ändern, 
außer der Inhalt dieser Register wurde vor seiner Änderung aufbewahrt und 
nach Abschluß der Routi ne zurückgespeichert. 

Beachten Sie, daß Sie die Unterbrechungen am Ende der Service-Routine 
nicht ausdrücklich wieder freigeben müssen. Der Grund hierfür ist, daß der 
RTI-Befehl automatisch das alte Statusregister (P) mit dem Unterbrechungs- 
Freigabebit in seinen ursprünglichen Zustand zurückversetzt. In der Tat werden 
Sie das Unterbrechungs-Freigabebit im Stapel (Bit 2 der obersten Speicherstel¬ 
le) ändern müssen, wenn Sie nicht wollen, daß die Unterbrechungen wieder frei¬ 
gegeben werden. 


ÄNDERN DER 
UNTERBRECHUNGS- 
RÜCKKEHR¬ 
ADRESSE 


Die Verwendung des Stapels ist die allgemeinste Lösung zum Aufbewahren 
und Zuruckspeichem von Registern. Der Befehl PHA bewahrt den Inhalt des 
Akkumulators im Stapel auf, und der Befehl PLA speichert den Inhalt des Ak¬ 
kumulators vom Stapel zurück. Dieses Verfahren kann unbegrenzt erweitert 
werden (solange es Platz im Stapel gibt), da verschachtelte Service-Routinen 
nicht die Daten zerstören werden, die in früheren Routinen aufbewahrt wur¬ 
den. 


Sie körnen alle Register Im Stapel aufbewahren (erinnern Sie sich daran, daß 
der Status automatisch gerettet wird) nach einer Unterbrechung mit der Se¬ 
quenz: 


PHA 

TXA 

PHA 

TYA 

PHA 


;BEWAHRE AKKUMULATOR AUF 
;BEWAHRE INDEXREGISTER X AUF 

;BEWAHRE INDEXREGISTER Y AUF 


Beachten Sie, daß es keinen direkten Weg zum Transferieren von Daten zwi¬ 
schen dem Stapel und den Indexregistern gibt. Der Inhalt des Akkumulators 
muß zuerst gerettet werden (weshalb?). 


Sie können die Register vom Stapel zurückspeichern (en nnern Sie sich daran, 
daß RTI automatisch den Status nach einer Unterbrechungs-Service-Routine zu- 
ruckspeichert) indem Sie die Daten vom Stapel in der entgegengesetzten Rei¬ 
henfolge entfernen, in der sie eingegeben wurden. 

iSPEICHERE INDEXREGISTER Y ZURÜCK 

iSPEICHERE INDEXREGISTER Y ZURÜCK 

;SPEICHERE AKKUMULATOR ZURÜCK 

Beachten Sie, daß der Akkumulator zuerst gerettet und zuletzt zurückgespei¬ 
chert wird. 


PLA 

TAY 

PLA 

TAX 

PLA 
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Eine alternative Lösung wäre, für die Unterbre- FÜLLEN EINES 

chungs-Routlne die Steuerung zu behalten, bis PUFFERS UBER 

eine gesamte Textzeile empfangen wurde (zum UNTERBRECHUNGEN 

Beispiel eine Reihe von Zeichen, endend mit 

einem Wagenrücklauf). Das Hauptprogramm 

wäre: 


Hauptprogramm: 

LDX #$FF .BRINGE STAPEL AN DAS ENDE 

. VON SEITE 1 

TXS 

LDA #0 

STA VIAPCR .MACHE ALLE STEUERLEITUNGEN ZU 

EINGÄNGEN 

STA VIADDRA ;MACHE PORT-A-LEITUNGEN ZU 

, EINGÄNGEN 

STA S40 ;LÖSCHE PUFFER-INDEX ZU BEGINN 

LDA #%10000010 

STA VIAIFR ;LOSCHE TASTATUR-UNTERBRECHUNGS 

, FLAG 

STA VIAIER ;GIB TASTATUR-UNTERBRECHUNG VON VIA 

. FREI 

CLI ;GIB CPU-UNTERBRECHUNG FREI 

HERE JMP HERE ;"DUMMY"-HAUPTPROGRAMM 


Unterbre chungs-Service-Routine: 


'-4NTRP 

PHA ;BEWAHRE AKKUMULATORIM STAPEL AUF 

TXA ;BEWAHRE INDEXREGISTER X IM STAPEL 

, AUF 

PHA 

LDX $40 ;HOLE PUFFER-INDEX 

LDA VIAORA ;HOLE TASTATUR-DATEN 

STA $41 X ;BEWAHRE DATEN IN PUFFER AUF 

CMP #CR ;SIND DATEN EIN WAGENRÜCKLAUF? 

BEO ENDL ;JA, ENDE DER ZEILE 

INC $40 .NEIN, INKREMENTIERE PUFFER-ZEIGER 

PLA tSPEICHERE INDEXREGISTER X VOM 

; STAPEL ZURÜCK 

TAX 

PLA ;SPEICHERE AKKUMULATOR VOM STAPEL 

; ZURÜCK 
RTI 

ENDL JMP LPROC ;SETZE OHNE UNTERBRECHUNGEN FORT 


Dieses Programm füllt einen Puffer, beginnend beim Speicherplatz 0041, bis es 
ein Wagenrücklauf-Zeichen (CR) empfängt. Der Speicherplatz 0040 beinhaltet 
den momentanen Puffer-Index. 

Wenn der Prozessor einen Wagenrücklauf empfängt, läßt er das Unterbre¬ 
chungssystem gesperrt, während er diese Zeile verarbeitet 

Eine alternative Lösung wäre das Füllen eines VERDOPPELN 

anderen Puffers, während das erste bearbeitet DES PUFFERNS _ 

wird. Diese Lösung wird "doppelte Pufferung" ge¬ 
nannt. 
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Die Verarbeitungs-Routine für die Zeile hat bei der Adresse LPROC mit gesperr¬ 
ten Unterbrechungen begonnen und mit dem ursprünglichen Inhalt der Register 
(P, A und X) sowie der Rückkehr-Adresse im Stapel. 

In einer realen Anwendung könnte die CPU andere Aufgaben zwischen den Un¬ 
terbrechungen ausführen. Sie könnte zum Beispiel eine Zeile editieren oder von 
einem Puffer zu einem anderen übertragen, während die Unterbrechung einen 
weiteren Puffer lüllt 


Eine Drucker-Unterbrechung 

Zweck: Der Computer wartet auf eine Drucker-Unterbrechung und sendet die 
Daten vom Speicherplatz 0040 zum Drucker. 

Beispiel: 

(0040) = 51, s 

Ergebnis: Der Drucker empfängt ein 51 1s (ASCII O), wenn er bereit ist. 

Flußdiagramm: 



Quell-Programm: 

Hauptprogramm: 


LDX 

#$FF 

.LEGE STAPEL AN DAS ENDE VON SEITE 1 

TXS 

STX 

VIADDRB 

;MACHE PORT-B-LEITUNGEN ZU 

LDA 

#0 

; AUSGÄNGEN 

STA 

VIAPCR 

.MACHE ALLE STEUERLEITUNGEN ZU 

LDA 

#%10000010 

; EINGÄNGEN 
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STA 

VIAIFR 

.LÖSCHE DRUCKER-UNTERBRECHUNGS- 
, FLAG 

STA 

VIAIER 

.GIB DRUCKER-UNTERBRECHUNG VON VIA 
, FREI 

CLI 


.GIB CPU-UNTERBRECHUNGEN FREI 

JMP 

HERE 

;’'DUMMY"-HAUPTPROGRAMM 


Unterbrechungs-Service-Routine: 

•-INTRP 
PHA 

LDA $40 
STA VIAORB 
PLA 

RTI 


BEWAHRE AKKUMULATOR IN STAPEL AUF 
HOLE DATEN 

SENDE DATEN ZU DRUCKER 
SPEICHERE AKKUMULATOR VON STAPEL 
ZURÜCK 


Objektprogramm: 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) 

Hauptprogramm: 




0000 

A2 

LDX 

#$FF 

0001 

FF 



0002 

9A 

TXS 


0003 

BE 

STX 

VIADDRB 

0004i 

00051 

VIADDRB 



0006 

A9 

LDA 

#0 

0007 

00 



0008 

8D 

STA 

VIAPCR 

00091 

000AI 

VIAPCR 



0008 

A9 

LDA 

#9410000010 

oooc 

82 



000D 

8D 

STA 

VIAIFR 

000E» 

000FI 

VIAIFR 



0010 

8D 

STA 

VIAIER 

0011» 

0012» 

VIAIER 



0013 

58 

CLI 


0014 

4C HERE 

JMP 

HERE 

0015 

14 



0016 

00 



Unterbrechungs-Seivice-Routme: 



INTRP 

48 

PHA 


INTRP+1 

A5 

LDA 

$40 

INTRP+2 

40 



INTRP+3 

8D 

STA 

VIAORB 

INTRP+4» 

INTRP-t-51 

VIAORB 



INTRP+6 

68 

PLA 


INTRP+7 

40 

RTI 



Hier, so wie bei der Tastatur, könnten wir den 
Drucker weiter unterbrechen lassen, bis die gan¬ 
ze Textzeile übertragen ist. Das Hauptprogramm 
und die Service-Routine wären dann: 

Hauptprogramm: 


leeren eines 
PUFFERS MIT 

Unterbrechungen 


HERE 


LDX 

TXS 

STX 

LDA 

STA 

STA 

LDA 

STA 

STA 

CLI 

JMP 


#SFF 


VIADDRB 

#0 

VIAPCR 

$40 

#%1 0000010 
VIAIFR 

VIAIER 


HERE 


;LEGE STAPEL AN DAS ENDE VON SEITE 1 
;MACHE PORT-B-LEITUNGEN ZU 
; AUSGÄNGEN 

;MACHE ALLE STEUERLEITUNGEN ZU 
. EINGÄNGEN 

INITIALISIERE PUFFER-INDEX AUF NULL 

;LÖSCHE DRUCKER-UNTERBRECHUNGS 
, FLAG 

•GIB DRUCKER-UNTERBRECHUNG VON VIA 
i FREI 

;GIB CPU-UNTERBRECHUNG FREI 
;”DUMMY"-HAUPTPROGRAMM 


Unterbrechungs-Service-Routine: 


*=INTRP 

PHA 

TXA 

PHA 

LDX $40 
LDA $41,X 
STA VIAORB 
CMP #CR 
BEQ ENDL 
INC $40 
PLA 

TAX 

PLA 

RTI 

ENDL JMP LCOMP 


;BEWAHRE AKKUMULATOR IN STAPEL AUF 
.BEWAHRE INDEXREGISTER X IN STAPEL 
; AUF 


;HOLE EIN DATENBYTE VON PUFFER 
iSENDE DATEN ZUM DRUCKER 
;SIND DATEN EIN WAGENRÜCKLAUF? 

;JA, ENDE DER ZEILE 
,'NEIN, INKREMENTIERE PUFFERZEIGER 
iSPEICHERE INDEXREGISTERX VOM 
: STAPEL ZURÜCK 


iSPEICHERE AKKUMULATOR VOM STAPEL 
; ZURÜCK 

iBEARBEITE VOLLSTÄNDIGE ZEILE 


Wiederum könnte doppelte Pufferung verwendet werden, damit E/A und Ver¬ 
arbeitung zur gleichen Zeit aultritt, ohne jemals die CPU anzuhalten. 
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Eine Echtzeit-Takt-Unterbrechung 5 ’ 6 


Zweck: Der Computer wartet auf eine Unterbrechung von 
einem Echtzeit-Takt 5 ' 5 . 


Ein Echtzeit-Takt liefert einfach eine gleichmäßige Serie von Impulsen. Das In¬ 
tervall zwischen den Impulsen kann als Zeitreferenz verwendet werden. Echt- 
zeittakt-Unterbrechungen können gezählt werden, um jedes Vielfache des 
grundlegenden Zeitintervalls zu geben. Ein Echtzeit-Takt kann durch Teilendes 
CPU-Taktes gebildet werden, durch einen separaten Zeitgeber oder einen pro¬ 
grammierbaren Zeitgeber, wie der im VIA 6522 oder in den Mehrfunktions-Bau- 
steinen 6530 oder 6532 (siehe Kapitel 11), oder durch Verwendung externer 
Quellen, wie etwa der Wechselspannungs-Netzfrequenz, 


Beachten Sie die Überlegungen bei der Bestim¬ 
mung der Frequenz des Echtzeit-Taktes. Eine 
hohe Frequenz (etwa 10 kHz) gestattet die Erzeu¬ 
gung eines weiten Bereiches von Zeitintervallen 
mit hoher Genauigkeit. Andererseits kann der Aufwand beim Zählen von Echt¬ 
zeittakt-Unterbrechungen beträchtlich sein, und die Zählungen werden rasch die 
Kapazität eines einzelnen 8-Bit-Registers oder Speicherplatzes übersteigen. Die 
Wahl der Frequenz hängt von der Genauigkeit und den zeitlichen Anforderun¬ 
gen ihrer Anwendung ab. Der Taktgenerator kann natürlich zum Teil aus Hard¬ 
ware bestehen. Ein Zähler könnte die Hochfrequenz-Impulse zählen und 
den Prozessor nur gelegentlich unterbrechen Ein Programm muß dann den 
Zähler lesen, um die Zeit mit hoher Genauigkeit zu messen. 


Ein Problem stellt die Synchronisation von Ope¬ 
rationen mit dem Echtzeit-Takt dar. Offensicht¬ 
lich wird hier ein gewisser Einfluß auf die Ge¬ 
nauigkeit des Zeilintervalles vorliegen, wenn die CPU die Messung zufällig wäh¬ 
rend der Taktperiode beginnt, anstatt exakt am Anfang zu starten. Einige Mög¬ 
lichkeiten zur Synchronisation von Operationen sind: 

1) Staiten Sie die CPU und den Takt zusammen. RESET oder eine Start-Unter¬ 
brechung können sowohl denTakt wie die CPU starten. 

2) Gestatten Sie der CPU, den Takt mittels Programmsteuerung zu starten und 
zu stoppen. 

3) Verwenden Sie einen hochfrequenten Takt, so daß ein Fehler von weniger 
alseinerTaktperiode klein sein wird. 

4) Stellen Sie den Takt (indem Sie auf eine Flanke oder Unterbrechung warten) 
vor dem Staden der Messung. 


Eine Echtzeittakt-Unterbrechung sollte eine sehr 
hohe Priorität besitzen, da die Genauigke'rt der 
Zeitintervalle durch jede Verzögerung beim Be¬ 
dienen der Unterbrechung beeinflußt wird. Die Praxis besteht gewöhnlich darin, 
dem Echtzeit-Takt die höchste Unterbrechungs-Priorität zu geben, mit Ausnah¬ 
me für einen Betriebsspannungs-Ausfall. Die Unterbrechungs-Service-Routine 
des Taktes wird im allgemeinen extrem kurz gehalten, so daß sie andere CPU- 
Aktivitäten nicht stört. 


PRIORITÄT EINER 
ECHTZEIT-UHR 


SYNCHRONISATION 
MIT ECHTZEIT-TAKT 


FREQUENZ 
EINES ECHT¬ 
ZEIT-TAKTES 


ECHT-ZEIT- 

TAKT 


a) Waden auf einen Echtzeit-Takt 
Quellprogramm: 

Hauptprogramm: 


HERE 


LDX 

TXS 

#$FF 

LDA 

#0 

STA 

VIAPCR 

LDA 

#%10000010 

STA 

VIAIFR 

STA 

CLI 

VIAIER 

JMP 

HERE 


,LEGE STAPEL AN ENDE VON SEITE 1 


;MACHE ALLE STEUERLEITUNGEN 
; ZU EINGÄNGEN 

;LÖSCHE TAKTUNTERBRECHUNGS-FLAG 
;GIB TAKT-UNTERBRECHUNG VON VIA FREI 
;GIB CPU-UNTERBRECHUNG FREI 
;"DUMMY”-HAUPTPROGRAMM 


Unterbrechungs-Service- Routine: 


*-!NTRP 

PHA 

LDA #%10000010 
STA VIAIFR 
PLA 

BRK 


;BEWAHRE AKKUMULATOR IN STAPEL AUF 

iLÖSCHE TAKTUNTERBRECHUNGS-FLAG 
;SPEICHERE AKKUMULATOR VON STAPEL 
; ZURÜCK 
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Objektprogramm: 


Erinnern Siesich an folgendes: 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 


Befehl 

(Mnemonik) 

Hauptprogramm: 





0000 

A2 


LDX 

#$FF 

0001 

FF 




0002 

9A 


TXS 


0003 

A9 


LDA 

#0 

0004 

00 




0005 

8D 


STA 

VIAPCR 

0006J 

V1APCR 




00071 





0008 

A9 


LDA 

#%10000010 

0009 

82 




OOOA 

8D 


STA 

VIAIFR 

000BI 

VIAIFR 




000CI 





000D 

BO 


STA 

VIAIER 

000E1 

VIAIER 




000F« 





0010 

58 


CLI 


0011 

4C 

HERE 

JMP 

HERE 

0012 

11 




0013 

00 




Unterbrechungs-Service-Routine: 




INTRP 

48 


PHA 


INTRP+1 

A9 


LOA 

#%10000010 

INTRP+2 

82 




INTRP+3 

80 


STA 

VIAIFR 

INTRP+41 

VIAIFR 




INTRP+5) 





INTRP+6 

68 


PLA 


INTRp+7 

00 


BRK 



Wenn Bit 0 des VIA-Steuerregisters gleich 0 ist, wird die Unterbrechung an der 
abfallenden Ffanke des Taktes auftreten. Wenn dieses Bit 1 ist, wird die Unter¬ 
brechung an der ansteigenden Flanke des Taktes auftreten. 

Das Taktunterbrechungs-Flag muß in der Unterbrechungs-Seivice-Routine aus¬ 
drücklich gelöscht werden, da kein E/A-Transfer erforderlich ist. Beachten Sie, 
daß Port A noch für Daten verwendet werden könnte, solange diese Daten unter 
Veiwendung der Adresse transferiert wurden, die die Unterbrechungsllags nicht 
beeinflußt (siehe Tabelle 11-7). 


1) Die Zähler des Zeitgebers 1 werden von zwei Speicherplätzen (VIAT1L und 
VIAT1CH) geladen. Das Laden der höchstwertigen Bits der Zeitgeber-Zäh¬ 
lung in VIAT1CH startet den Zeitgeber und löscht das Tl-Unterbrechungs- 
flag (Bit 6 des Unterbrechungsflag-Registers) 

2) Die Betriebsart des Zeitgebers 1 wird durch die Bits 6 und 7 des Hilfs-Steu¬ 
erregisters bestimmt: 

Bit 6 = 0 für einen einzelnen Impuls und 1 für kontinuierliche 
Arbeitsweise 

Bit 7 - 0 zum Sperren der Ausgangsimpulse an PB7 und 1 zum 
Erzeugen derartiger Impulse. 

3) Der Abschluß des Zeitgeber-Intervalls setzt das Unterbrechungs-Flag des 
Zeitgebers 1 (Bit 6 des Unterbrechungsflag-Registers). 

Tabelle 11-7 beschreibt die Adressierung des VIA. Bild 11-10 beschreibt das 

Hilfs-Steuerregister und Bild 12 3 beschreibt das Unterbrechungsflag-Register. 

Hauptprogramm: 


LDX 

#$FF 


TXS 


.LEGE STAPEL AN DAS ENDE VON SEITE 1 

LDA 

#0 

STA 

VIAACR 

ERZEUGE EINEN IMPULS 



; VON ZEITGEBER 1 

LDA 

#%11 000000 


STA 

VIAIFR 

;LÖSCHE ZEITGEBERS-UNTERBRECHUNG 

STA 

VIAIER 

;GIB ZEITGEBER-1-UNTERBRECHUNG FREI 

LDA 

#$88 

IMPULSLÄNGE-5000 (1388 HEX) 

STA 

VIAT1 L 

LDA 

#$13 


STA 

VIAT1CH 

.STARTE ZEITGEBER INTERVALL 

CLI 


;GIB CPU-UNTERBRECHUNG FREI 

HERE JMP 

HERE 

;"DUMMY"-HAUPTPROGRAMM 


Unterbrechungs-Service-Routine: 


'-INTRP 

PHA ;BEWAHRE AKKUMULATOR IN STAPELAUF 

LDA #%11000000 

STA VIAIFR ;LÖSCHE TAKTUNTERBRECHUNGS-FLAG 

PLA SPEICHERE AKKUMULATOR VOM STAPEL 

; ZURÜCK 


BRK 


Die einzige Änderung in der Service-Routine ist die Position des Taktunterbre- 
chungs-Flags im Unterbrechungsflag-Register. 


Wir könnten natürlich den Impuls selbst unter Verwendung eines der Zeitgeber 
des 6522 erzeugen. Das folgende Beispiel verwendet Zeitgeber 1 zum Erzeu¬ 
gen eines einzelnen Impulses mit einer Länge von 5000 (1388te) Taktzyklen. 
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Objektprogramm: 


b) Warten auf 10 Echtzeittakt-Unterbrechungen 
Quellprogramm: 

Hauptprogramm 


WTTEN 


LDX 

TXS 

#$FF 

LDA 

#0 

STA 

VIAPCR 

STA 

$40 

LDA 

#%10000010 

STA 

VIAIFR 

STA 

VIAIER 

LDA 

CLI 

#10 

CMP 

$40 

BNE 

SEI 

BRK 

WTTEN 


;LEGE STAPEL AN DAS ENDE VON SEITE 1 


MACHE ALLE STEUERLEITUNGEN 
ZU EINGÄNGEN 
LÖSCHE TAKTZÄHLER 

LÖSCHE TAKTUNTERBRECHUNGS FLAG 
GIB TAKTUNTERBRECHUNG VON VIA FREI 
ANZAHL DERZÄHLUNGEN = 1 0 
GIB CPU-UNTERBRECHUNG FREI 
SIND ZEHN ZÄHLUNGEN ABGELAUFEN? 
NEIN, WARTE 

JA, SPERRE CPU-UNTERBRECHUNG 


Unterbrechungs-Service-Routme: 


*=INTRP 


PHA 


INC 

$40 

LDA 

#%1 0000010 

STA 

VIAIFR 

PLA 


RTI 



;BEWAHRE AKKUMULATOR IN STAPEL AUF 
;INKREMENTIERE TAKTZÄHLER 

;LÖSCHETAKTUNTERBRECHUNGS-FLAG 
;SPEICHERE AKKUMULATOR VOM STAPEL 
; ZURÜCK 


Natürlich könnten wir die Impulse von dem Zeitgeber des 6522 erzeugen - zum 
Beispiel könnten wir Zeitgeber 1 in seiner kontinuierlichen Betriebsart verwen¬ 
den (Bit 6 des Hilfs-Steuerregisters = 1). Die einzige andere Änderung wäre die 
Bit-Position des Unterbrechungs-Fiags. 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) 

Hauptprogramm 




0000 

A2 

LDX 

#$FF 

0001 

FF 



0002 

9A 

TXS 


0003 

A9 

LDA 

#0 

0004 

00 



0005 

8D 

STA 

VIAPCR 

0006) 




0007 i 

VIAPCR 



0008 

85 

STA 

$40 

0009 

40 



000A 

A9 

LDA 

#«10000010 

0008 

82 



OOOC 

8D 

STA 

VIAIFR 

000DI 




000E1 

VIAIFR 



000F 

8D 

STA 

VIAIER 

00101 




0011 i 

VIAIER 



0012 

A9 

LDA 

#10 

0013 

OA 



0014 

58 

CLI 


0015 

C5 

WTTEN CMP 

$40 

0016 

40 



0017 

DO 

BNE 

WTTEN 

0018 

FC 



0019 

78 

SEI 


001A 

00 

BRK 


Unterbrechungs-Service-Rcutine: 



INTRP 

48 

PHA 


INTRP+1 

E6 

INC 

$40 

INTRP+2 

40 



INTRP+3 

A9 

LDA 

#%10000010 

INTRP+4 

82 



INTRP+5 

80 

STA 

VIAIFR 

INTRP+61 




INTRP+71 

VIAIFR 



INTRP+8 

68 

PLA 


INTRP+9 

40 

RTI 



Diese Unterbrechungs-Service-Routine bringt einlach den Zähler im Speicher¬ 
platz 0040 auf den neuesten Stand. Es ist transparent für das Hauptprogramm. 


12-30 


12-31 







Eine realistischere Echtzeit-Unterbrechungs- 
Routine könnte Echtzeit in mehreren Speicherplät¬ 
zen aufbewahren. Zum Beispiel verwendet die fol¬ 
gende Routine die Adressen 0040 bis 0043 wie folgt: 


0040-Hundertstel Sekunden 
0041 - Sekunden 
0042 - Minuten 
0043-Stunden 

Wir nehmen an. daß die Routine mit einem Takt von 100 Hz getriggert wird 
Flußdiagramm: 



Quellprogramm: 

‘-INTRP 


PHA 


;BEWAHRE AKKUMULATOR IN STAPEL 



AUF 

LDA 

#%10000010 


STA 

VIAIFR 

;LÖSCHE TAKTUNTERBRECHUNGS-FLAG 

INC 

$40 

;BRINGE HUNDERTSTEL SEKUNDEN 



AUF LETZTEN STAND 

LDA 

$40 


SEC 


;GIBT ES EINEN ÜBERTRAG ZU DEN 



; SEKUNDEN? 

SBC 

#100 


BNE 

ENDINT 

;NEIN. DONE 

STA 

$40 

;JA, MACHE HUNDERTSTEL NULL 

INC 

$41 

;BRINGE SEKUNDEN AUF LETZTEN STAND 

LDA 

$41 


SBC 

#60 

;G!BT ES EINEN ÜBERTRAG ZU DEN 



; MINUTEN? 

BNE 

ENDINT 

;NEIN, DONE 

STA 

$41 

;JA, MACHE SEKUNDEN NULL 

INC 

$42 

;BRINGE MINUTEN AUF LETZTEN STAND 

LDA 

$42 


SBC 

#60 

;GIBT ES EINEN ÜBERTRAG ZU DEN 



. STUNDEN? 

BNE 

ENDINT 

.NEIN, DONE 

STA 

$42 

JA, MACHE MINUTEN ZU NULL 

INC 

$43 

iBRINGE STUNDEN AUF NEUESTEN 



STAND 

ENDINT PLA 


;SPEICHERE AKKUMULATOR VOM STAPEL 



: ZURÜCK 

RTI 



Nun könnte ein 

Warten von 300 ms im Hauptprogramm mit folgender Routine 

erzeugt werden: 



LDA 

$40 

,HOLE MOMENTANE ECHTZEIT 

CLC 



ADC 

#30 

iGEWÜNSCHTE ZEIT IST 30 ZÄHLUNGEN 



SPÄTER 

CMP 

#100 

,MOD 100 

BCC 

WAIT30 


SBC 

#100 


WAIT30 CMP 

$40 

;WARTE BIS ZUR GEWÜNSCHTEN ZEIT 

BNE 

WAIT30 



Wir brauchen nicht ausdrückliche Befehle SET CARRY (SEC), mit Ausnahme in 
der ersten Operation in der Unterbrechungs-Service-Routine. Die anderen Ope¬ 
rationen in der Unterbrechungs-Service-Routine werden nur ausgeführt, wenn 
die vorhergehende Subtraktion ein Null-Ergebnis erzeugte (und daher einen 
Übertrag von 1 erzeugte, wodurch ein Borgen angezeigt wird), In dem Warte¬ 
programm wird die Subtraktion überhaupt nur ausgeführt, wenn der Übertrag 1 
ist (andernfalls tritt eine Verzweigung auf). 

Natürlich könnte das Programm andere Aufgaben ausführen und nur die abge¬ 
laufene Zeit gelegentlich prüfen. Wie würden Sie eine Verzögerung von 7 Sekun¬ 
den erzeugen? 3 Minuten? 

Manchmal werden Sie vielleicht wollen, daß die Zeit entweder in BCD-Ziffern 
•der in ASCII-Zeichen vorliegt. Wie würden Sie das letzte Programm ändern, um 
diese Alternativen zu handhaben? 


AUFBEWAHRUNG 
DER ECHTZEIT 
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Sie können die Takt-Unterbrechung (oder jede SPERREN VON 
andere Unterbrechung) auf eine der folgenden UNTERBRECHUNGEN 
Wege sperren, wenn sie nicht länger benötigt 
wird: 


Eine Fernschreiber-Unterbrechung 

Zweck; Der Computer wartet auf zu empfangende Daten von einem Fernschreiber 
und speichert die Daten in den Speicherplatz 0040. 


1) Durch Ausführung eines SEI-Befehls im Hauptprogramm. Dies sperrt das 
gesamte Unterbrechungs-System. Ein SEI-Befehl in der Service-Routine hat 
keinen Einfluß, da RTI das alte I-Flag zurückspeichert. Tatsächlich sperrt der 
6502 Unterbrechungen automatisch während der Service-Routine. 

2) Durch Löschen des entsprechenden Bits des Unterbrechungs-Freigabe- 
Registers während der Service-Routine oder während des Hauptpro¬ 
gramms. Dies sperrt nur die einzige Unterbrechungs-Quelle von einem VIA. 

3) Durch Setzen des Unterbrechungs-Sperr-Flags im Stapel während der Ser¬ 
vice-Routine. Das folgende Programm würde diese Aufgabe ausführen (er¬ 
innern Sie sich daran, daß das Unterbrechungs Sperr-Flag das Bit 2 des 
Status-Registers ist und daß das Status-Register die oberste Eingabe in den 
Stapel darstellt (siehe Bild 12-1): 


PLA 

ORA 

PHA 


#%00000010 


HOLE STATUS-REGISTER 
SETZE UNTERBRECHUNGS-SPERR FLAG 
BRINGE STATUS-REGISTER VOM STAPEL 
ZURÜCK 


RTI wird dann eine Rückkehr zum Hauptprogramm bewirken, wobei das 
gesamte Unterbrechungs-System gesperrt ist 

Beachten Sie jedoch, daß Sie sehr sorgfältig vorgehen müssen und die Un¬ 
terbrechungen nicht automatisch wieder freigeben, da das Hauptprogramm 
überhaupt nicht wissen kann, daß Unterbrechungen nicht länger erlaubt 
sind. Im allgemeinen sollten alle Unterbrechungs-Servlce-Routinen die Un¬ 
terbrechungen wieder vor der Rückkehr freigeben. Jede andere Politik be¬ 
deutet, daß die Service-Routinen nicht transparent für das Hauptpro¬ 
gramm sind. 


a) Verwendung eines ACIA 6850 

(7-Bit-Zeichen mit ungerader Parität und zwei 
Stop-Bits.) 


ACIA- 

UNTERBRECHUNGS- 

ROUTINE 


Quellprogramm: 


Hauptprogramm: 


LDX 

TXS 

LDA 

STA 

LDA 

STA 

CLl 

HERE HMP 


#SFF ;BRINGE STAPEL AN DAS ENDE VON 

; SEITEI 

#%00000011 ;HAUPT-RESET DES ACIA 
ACiACR 

#%11000101 ;GIB ACiA-UNTERBRECHUNG FREI 
ACIACR 

;GIB CPU-UNTERBRECHUNG FREI 
HERE ;"DUMMY" HAUPTPROGRAMM 


Unterbrechungs-Service-Routine: 


‘-INTRP 

nLJ '' BEWAHRE AKKUMULATOR IN STAPEL AUF 

HOLE DATEN VON ACtA 
BEWAHRE DATEN AUF 
SPEICHERE AKKUMULATOR VOM STAPEL 
ZURÜCK 
RTI 


LDA ACIADR 
STA S40 
PLA 
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Objektprogramm: 


Speicher Adresse 
(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) 

Hauptprogramm. 




0000 

A2 

LDX 

#$FF 

0001 

FF 



0002 

9A 

TXS 


0003 

A9 

LDA 

#%000000t1 

0004 

03 



0006 

80 

STA 

ACIACR 

00061 

00071 

ACIACR 



0000 

A9 

LOA 

#%11000101 

0009 

C5 



OOOA 

8D 

STA 

ACIACR 

0006 » 

oooct 

ACIACR 



QOOD 

58 

CU 


OOOE 

4C HERE 

JMP 

HERE 

000F 

OE 



0010 

00 



Unterbrechungs-Service-Routine: 



INTRP 

48 

PHA 


INTRP+1 

AD 

LDA 

ACIADR 

INTRP+21 

INTRP+31 

ACIADR 



INTRP+4 

85 

STA 

$40 

1NTRP+5 

40 



INTRP+6 

68 

PLA 


INTRP+7 

40 

RTl 



Erinnern Sie sich daran, daß der ACIA keinen RESET-Eingang besitzt, so daß ein 
"MASTER-RESET” (der die Steuerregister-Bits 0 und 1 beide ”1" macht) erfor¬ 
derlich ist, bevor der ACIA verwendet wird. Die Konfiguration der ACtA-Steuer- 
register ist: 


b) Verwendung eines VIA 6522 

(Empfangene Daten werden sowohl zum Da¬ 
tenbit 7 wie zur Steuerleitung 1 des VIA ge¬ 
führt.) 

Oueilprogramm: 


Hauptprogramm: 


LDX 

TXS 

#$FF 

;LEGE STAPEL AN DAS ENDE VON SEITE 1 

LDA 

#0 


STA 

VIAPCR 

;MACHE ALLE STEUERLEITUNGEN 

STA 

VIADDRA 

: ZU EINGÄNGEN 

LDA 

#%1 0000010 


STA 

VIAIFR 

LÖSCHE START-BIT-UNTERBRECHUNGS- 

STA 

VIAIER 

FLAG 

GIB STARTBIT-UNTERBRECHUNG VON VIA 

CLI 


FREI 

GIB CPU-UNTERBRECHUNG FREI 

HERE JUMP 

HERE 

"•DUMMY” HAUPTPROGRAMM 

Unterbrechungs-Service-Routine: 


*=tNTRP 

PHA 

:BEWAHRE AKKUMULATOR IN STAPEL AUF 

LDA 

#%00000010 


STA 

VIAIFR 

LÖSCHE STARTBIT-UNTERBRECHUNGS¬ 

STA 

VIAIER 

FLAG 

GIB STARTBIT-UNTERBRECHUNG FREI 

JSR 

TTYRCV 

HOLE DATEN VON TTY 

LDA 

#%10000010 


STA 

VIAIER 

GIB STARTBIT-UNTERBRECHUNG WIEDER 

PLA 


FREI 

SPEICHERE AKKUMULATOR VOM STAPEL 

RTl 


ZURÜCK 


START-BIT¬ 

UNTERBRECHUNG 


Bit 7 = 1, zur Freigabe der Empfangs-Unterbrechung 
Bit 6 = 1, Bit 5 = 0 zur Sperrung der Sender-Unterbrechung 
und um RTS High (inaktiv) zu machen. 

Bit 4 = 0. Bit 3 = 0. Bit 2 - 1, um 7-Bit-Daten mit gerader Pari¬ 
tät und zwei Stop-Bits auszuwählen. 

Bit 1=0, Bit 0 = 1 für h- 16 Takt (1760 Hz). 

Um zu bestimmen, ob ein spezieller ACIA die Quelle einer Unterbrechung ist. 
muß die CPU das Unterbrechungs-Anforderungs-Bit. Bit 7 des Statusregisters, 
prüfen. Das Programm muß das Bit "Receive Data Register Full" (Statusregister- 
Bit 0) und das Bit "Transmitter Data Register Empty” (Statusregister-Bit 1) prü¬ 
fen, um zwischen Empfangs- und Sende-Unterbrechungen zu unterscheiden. 

Entweder löscht das Lesen des Empfangsdaten-Registers oder das Schreiben 
in das Sendedaten-Register das ACIA-Unterbrechungs-Anforderungsbit. 
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Objektprogramm: 


Speicher-Adresse 

(Hex) 

Speicher-Inhalt 

(Hex) 

Befehl 

(Mnemonik) j 

Hauptprogramm 




0000 

A2 

LDX 

#$FF 

0001 

FF 



0002 

9A 

TXS 


0003 

A9 

LDA 

#0 

0004 

00 



0005 

8D 

STA 

VIAPCR 

00061 

00071 

VIAPCR 



0008 

8D 

STA 

VIADDRA 

00091 

OOOAf 

VIADDRA 



000B 

A9 

LDA 

#%10000010 

oooc 

82 



000D 

8D 

STA 

VIAIFR 

000E 

000F 

VIAIFR 



0010 

BD 

STA 

VIAIER 

00111 

00121 

VIAIER 



0013 

58 

CU 


0014 

4C HERE 

JMP 

HERE 

0015 

14 



0016 

00 



1 Urterbrechungs-Servtce-Routine: 



INTRP 

48 

PHA 


INTRP+1 

A9 

LDA 

#%00000010 

INTRP+2 

02 



INTRP+3 

8D 

STA 

VIAIFR 

INTRP+41 

INTRP+5I 

VIAIFR 



INTRP+6 

8D 

STA 

VIAIER 

INTRP+71 

INTRP+81 

VIAIER 



INTRP+9 

20 

JSR 

TTYRCV 

INTRP+101 
INTRP+111 

TTYRCV 



INTRP+12 

A9 

LDA 

#%10000010 

INTRP+13 

82 



INTRP+14 

8D 

STA 

VIAIER 

INTRP+151 

INTRP+161 

VIAIER 



INTRP+17 

68 

PLA 


INTRP+18 

40 

RTI 



Das Unterprogramm TTYRCV ist die Fernschreiber-Empfangs-Routine, die im 
vorhergehenden Kapitel gezeigt wurde. 

Die verwendete Flanke, die die Unterbrechung bewirkt, ist hier sehr wichtig. Der 
Übergang vom normalen ’T’-Zustand (MARK) zum "0"-Zustand (SPACE) muß 
die Unterbrechung bewirken, da dieser Übergang den Start der Übertragung 
kennzeichnet Es wird kein "0"-auf-"1 "-Übergang auftreten. bis ein Nicht-Nuii- 
Datenbit empfangen wird. 

Die Service-Routine muß die VIA-Unterbrechung sperren, da sonst jeder 
, T’-auf-"0’ , -Übergang im Zeichen eine Unterbrechung bewirken wird. Natürlich 
müssen Sie die VIA-Unterbrechung wieder freigeben, nachdem das ganze Zei¬ 
chen gelesen worden ist. 

Beachten Sie, wie VIA-Unterbrechungen freigegeben oder gesperrt werden. Bit 7 
des Unterbrechungs-Freigaberegisters ist ein "Setz-Lösch-Steuer"-Bit. Wenn 
dieses Bit 0 ist, löschen darauf folgende 1-Bits die Unterbrechungsfreigabe-Bits 
und sperren daher die entsprechenden Unterbrechungen. Wenn dieses Bit 1 ist, 
setzen darauffolgende 1-Bits die Unterbrechungsfreigabe-Bits und geben daher 
die entsprechenden Unterbrechungen frei. Der Prozessor kann in Wirklichkeit 
nicht in das Bit 7 des Unterbrechungsflag-Registers schreiben, so daß entweder 
ein Freigabe- oder Sperr-Muster zum Löschen der Unterbrechungsffags verwen¬ 
det werden kann. Erinnern sie sich an die Beschreibung des Unterbrechungs¬ 
freigabe-Registers und der Unterbrechungsflag-Register in den Bildern 12-2 und 
12 3. 
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ALLGEMEINERE SERVICE-ROUTINEN 


AUFGABEN FÜR 

Allgemeinere Service-Routinen, die ein Teil eines ALLGEMEINE 
vollständigen unterbrechungs-gesteuerten Systems SERVICE- 
sind, müssen folgende Aufgaben erfüllen: ROUTINEN 


1) Aufbewahren aller Register, die in der Unterbrechungs-Service-Routine im 
Stapel verwendet werden, so daß das unterbrochene Programm korrekt 
wiederaufgenommen werden kann. 


Erinnnern Sie sich daran, daß der 6502 nur Push-Befehle für den Akkumula¬ 
tor und für das Statusregister P besitzt. Das "Pushen" des Statusregisters 
ist nach einer Unterbrechung nicht eriorderilich, da die Unterbrechungs- 
Reaktion dies automatisch ausführt. Eine Routine zum Aufbewahren aller 
Register in den Stapel würde sein (wie früher gezeigt): 


PHA 

;BEWAHRE 

AUF 

TXA 

iBEWAHRE 


; AUF 

PHA 


TYA 

iBEWAHRE 


; AUF 

PHA 



AKKUMULATOR IN STAPEL 
INDEXREGISTER X IM STAPEL 

INDEXREGISTER Y IM STAPEL 


In einigen 6502-Programmen werden bestimmte Speicherplätze auf der 
Nullseite als zusätzliche Register behandelt. Derartige Speicherplätze 
müssen möglicherweise aufbewahrt und während Unterbrechungs-Ser- 
vice-Routinen wieder zurückgespeichert werden. Das Verfahren zum Auf¬ 
bewahren des Inhalts des Speicherplatzes 0040 würde zum Beispiel sein: 


LDA $40 
PHA 


iBEWAHRE SPEICHERPLATZ 0040 IM 
; STAPEL AUF 


Natürlich müssen nur lene Register, die von der Unterbrechungs-Service- 
Routine verwendet werden, aufbewahrt werden. 


2) Zurückspeichem aller Register vom Stapel nach Abschluß der Unterbre¬ 
chungs-Service-Routine. Ennnern Sie sich daran, daß Register in der entge¬ 
gengesetzten Reihenfolge zurückgespeichert werden, in der sie aufbewahrt 
wurden. 

3) Ordnungsgemäße Freigabe und Sperren von Unterbrechungen. Erinnern 
Sie sich daran, daß die CPU automatisch ihre Unterbrechungen sperrt, so¬ 
bald sie eine hiervon empfängt. 

Die Service-Routinen sollten transparent sein, sowe'rt es das Unterbrechungs¬ 
programm betrifft (d.h,, es sollte keine zufälligen Effekte bewirken). 


Jedes Standard-Unterprogramm, das von einer Unterbrechungs-Service-Rou¬ 
tine verwendet wird, muß ”re-entrant" sein, das heißt, es muß in dieses wieder 
eingetreten werden können. Wenn einige Unterprogramme nicht "re-entrant" 
gemacht werden können, muß die Unterbrechungs-Service-Routine verschie¬ 
dene Versionen für Ihre Verwendung besitzen. 7 
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AUFGABEN 

1) Eine Test-Unterbrechung 

Zweck: Der Computer wartet, bis eine VIA-Unterbrechung auftritt, dann führt er 
den endlosen Schleifenbefehl 

HERE JMP HERE 
aus, bis die nächste Unterbrechung auflritt. 

2) Eine Tastatur-Unterbrechung 

Zweck: Der Computer wartet auf eine vierstellige Eingabe von einer Tastatur 
und plaziert die Stellen in die Speicherplätze 0040 bis 0043 (die erste 
empfangene Stelle in 0040) Jede Eingabe einer Stelle bewirkt eine Un¬ 
terbrechung. Die vierte Eingabe sollte ein Sperren der Tastatur-Unter¬ 
brechung ergeben. 

Beispiel: 

Tastatur-Daten = 04.06,01,07 

Ergebnis: (0040) = 04 
(0041) = 06 
(0042) = 01 
(0043) - 07 

3) Eine Drucker-Unterbrechung 

Zweck: Der Computer sendet vier Zeichen von den Speicherplätzen 0040 bis 
0043 (beginnend mit 0040) zum Drucker. Jedes Zeichen wird durch 
eine Unterbrechung angefordert. Die vierte Übertragung sperrt auch die 
Drucker-Unterbrechung. 

4) Eine Echtzeit-Takt-Unterbrechung 

Zweck: Der Computer löscht anfangs den Speicherplatz 0040 und komplemen¬ 
tiert dann den Speicherplatz 0040 jedesmal, wenn eine Echtzeittakt- 
Unterbrechung auftritt. 

Wie würden sie das Programm ändern, so daß es den Speicherplatz 
0040 nach jeweils zehn Unterbrechungen komplementiert? Wie würden 
sie das Programm ändern, so daß es den Speicherplatz 0040 während 
zehn Taktperioden auf null läßt, FF 16 für fünf Taktperioden und so weiter 
kontinuierlich? Sie könnten die Verwendung einer Anzeige wünschen 
anstalt des Speicherplatzes 0040, so daß es leichter zu sehen ist. 

5) Eine Fernschreiber-Unterbrechung 

Zweck: Der Computer empfängt Daten von einem unterbrechenden ACIA 
6850 und speichert die Zeichen in einen Puffer, beginnend im Spei¬ 
cherplatz 0040. Der Vorgang wird so lange fortgesetzt, bis der 
Computer einen "Wagenrücklauf" (0D 1b ) empfängt. Nehmen Sie 
an, daß die Zeichen 7 Bit ASCII mit ungerader Parität sind. Wie 
würden Sie Ihr Programm zur Verwendung eines VIA ändern? Neh¬ 
men Sie an, daß das Unterprogramm TTYRCV verfügbar ist wie in 
dem vorhergehenden Beispiel. Schließen Sie den "Wagenrücklauf" 
als Abschluß-Zeichen in den Puffer mit ein. 
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Kapitel 13 

AUFGABEN-DEFINITION UND 
PROGRAMM-ENTWICKLUNG 


DIE AUFGABEN DER SOFTWARE-ENTWICKLUNG 

in den voraus gehenden Kapiteln haben wir uns auf das Schreiben kurzer Pro¬ 
gramme in Assemblersprache konzentriert. Wenn dies auch ein wesentlicher 
Punkt ist, so ist es nur ein kleiner Teil der gesamten Aufgabe der Software- 
Entwicklung. Obwohl das Schreiben von Assemblersprachen-Programmen für 
den Neuling eine Hauptaufgabe zu sein scheint, wird sie bald verhältnismäßig 
einfach. Sie sollten nunmehr mit den meisten der Standardmethoden für die Pro¬ 
grammierung in Assemblersprache des Mikroprozessors 6502 vertraut sein. Die 
nächsten vier Kapitel werden beschreiben, wie man Aufgaben in Form von 
Programmen formuliert und wie man kurze Programme zusammenfügt, um ein 
arbeitendes System zu bilden. 


Software-Entwicklung besteht aus mehreren Stufen. Bild 
13-1 ist ein Flußdiagramm des Vorgangs der Software- 
Entwicklung 


Seine Stufen sind: 

• Definition der Aufgabe 

• Programm-Entwicklung 

• Codierung 

• Fehlersuche 

• Testen 

• Dokumentieren 

• Wartung und Neu-Entwicklung 

jede dieser Stufen ist wichtig zum Aufbau eines funktionierenden Systems 
Beachten Sie. daß die Codierung, das Schreiben von Programmen in einer 
Form, die der Computer versteht, nur eine von sieben Stufen darstellt 


In der Tat ist die Codierung gewöhnlich die am 
einfachsten zu definierende und auszuführende 

Stufe. Die Regeln für das Schreiben von Com- 
puterprogrammen sind leicht zu erlernen. 

Sie variieren etwas von Computer zu Computer, jedoch die grundlegenden 
Techniken bleiben gleich. Wenige Software-Projekte geben Ärger infolge der 
Codierung. In der Tat ist die Codierung nicht der wichtigste Teil der Software- 
Entwicklung Fachleute schätzen, daß ein Programmierer ein bis zehn voll 
iehlertrei gemachte und dokumentierte Anweisungen pro Tag schreiben kann 
Offensichtlich ist die bloße Codierung von ein bis zehn Anweisungen kaum eine 
Arbeit für einen ganzen Tag, Bei den meisten Software-Projekten benötigt die 
Codierung weniger als 25% der Zeit des Programmierers 


RELATIVE 
BEDEUTUNG DER 
CODIERUNG 


STUFEN DER 
SOFTWARE¬ 
ENTWICKLUNG 
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Die Messung des Fortschrittes in den anderen 
Stufen ist schwierig. Man kann sagen, daß die 
Hälfte des Programmes geschrieben wurde, aber 
Sie können kaum sagen, daß die Hälfte der Feh¬ 
ler entfernt wurde oder die Hälfte der Auf¬ 
gabe definiert wurde. Zeit-Tabellen für derartige 
Stufen wie Programm-Entwicklung, Fehlersuche und Testen sind schwierig her¬ 
zustellen. VieleTage oder Wochen voller Anstrengung können unter Umständen 
in keinem offensichtlichen Fortschritt resultieren. Ferner kann eine unvollständi¬ 
ge Arbeit in einer Stufe später in schwerwiegenden Problemen resultieren. Zum 
Beispiel kann eine schlechte Aufgaben-Definition oder Programm Entwicklung 
die Fehlersuche und das Testen sehr schwierig machen, ln einer Stufe ge¬ 
sparte Zeit kann sehr viel Zeit in späteren Stufen kosten. 


MESSEN DES 
FORTSCHRITTS 
IN DEN STUFEN 


C Start J 


Aufgaben* 
Definition 


I 


Programm- 

Entwicklung 


Coderung 



Fehler 
? 


OofcumenMkri 


Weitung und 
Neuentwicklung 


^ Ende ^ 


Bild 13-1. Flußdiagramm der Software-Entwicklung. 
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DEFINITION DER STUFEN 


Die Definition einer Aufgabe besteht in der Formulierung 
der Aufgabe in Ausdrücken der Forderungen, die an den 
Computer gestellt werden. Was ist zum Beispiel erforder¬ 
lich, daß ein Computer ein Werkzeug steuert, eine Serie von elektrischen 
Tests ausführt, oder die Kommunikation zwischen einem zentralen Steuergerät 
und einem entfernt stehenden Instrument ausführt? Die Aufgaben-Definition 
erfordert, daß Sie die Form und die Geschwindigkeit der Eingaben und Ausga¬ 
ben bestimmen, den erforderlichen Umfang und die Geschwindigkeit der Verar¬ 
beitung und die Arten der möglichen Fehler und deren Beseitigung. Die Defini¬ 
tion der Aufgabe setzt eine einigermaßen definierte Vorstellung des Aufbaues 
eines computer-gesteuerten Systems voraus und definiert die Aufgaben und 
Anforderungen an den Computer. 


Betreuung und Neu-Entwicklung steilen die War¬ 
tung, Verbesserung und Erweiterung des Pro¬ 
grammes dar. Natürlich muß der Entwickler be¬ 
reit sein, Anwender-Probleme mit einem auf Computer basierenden Gerät zu 
handhaben, Es können hierzu Diagnostik-Verfahren oder Programme und an¬ 
dere Hilfsmittel erforderlich sein. Verbesserung oder Erweiterung des Program¬ 
mes kann notwendig sein um eine neue Anforderung zu erfüllen oder neue 
Aufgaben zu erledigen. 

Der Rest dieses Kapitels wird sich nur mit der Aufgaben-Definition und den 
Programm-Entwichlungsstufen befassen. Kapitel 14 wird die Fehlersuche und 
das Testen besprechen, und Kapitel 15 wird die Dokumentation. Erweiterung 
und Neu-Entwicklung behandeln. Wir werden alle Stufen in einigen einfachen 
System-Beispielen in Kapitel 16 zusammenfügen. 


AUFGABEN¬ 

DEFINITION 


BETREUUNG UND 
NEU-ENTWICKLUNG 


Programm-Entwicklung stellt einen Umriß des Computer¬ 
programmes dar, das die definierte Aufgabe ausführen 
wird. In dieser Entwicklungsstufe werden die Aufgaben auf 
eine Weise beschrieben, in der sie leicht in ein 
Programm umgesetzt werden können. Nützliche Techniken in dieser Stufe sind 
das Aufstellen eines Flußdiagrammes, strukturierte Programmierung, modu¬ 
lare Programmierung und das Verfahren der "schrittweisen Verfeinerung" (top- 
down-design). 


AUFGABEN-DEFINITION 

Typische Mikroprozessor-Aufgaben erfordern eine gründliche Definition. Zum 
Beispiel, was muß ein Programm ausführen, um eine Waage, eine Registrier¬ 
kasse oder einen Signal Generator zu steuern? Offensichtlich bereitet es nicht 
wenig Mühe, allem die entsprechenden Aufgaben exakt zu definieren. 


PROGRAMM¬ 

ENTWICKLUNG 


CODIERUNG 


Codierung ist das Schreiben des Programmes in einer 
Form, die der Computer entweder direkt verstehen oder 
übersetzen kann. 

Die Form kann Maschinensprache, Assemblersprache oder eine höhere Pro 
grammiersprache sein. 


DEFINITION DER EINGABEN 

Wie sollen wir die Definition beginnen? Es ist naheliegend mit den Eingaben an¬ 
zufangen. Hierzu sollten wir eine List aller Eingangs-Signale aufstellen, die 
der Computer in dieser Anwendung empfängt. 


FEHLERSUCHE 


Fehlersuche und Fehlerbeseitigung (debugging), auch Pro¬ 
gramm-Überprüfung genannt, macht das Programm so, 
daßes entsprechend der Spezifikationen arbeitet. 

In dieser Stufe verwenden Sie Hilfsmittel wie Haltepunkte, Simulatoren, Logik- 
Analysatoren und In-Circuit-Emulatoren. Das Ende dieser Stufe ist schwer zu 
definieren, da sie niemals wissen, ob sie den letzten Fehler gefunden haben 


TESTEN 


Testen, manchmal auch Programm-Gültigkeitsprüfung ge¬ 
nannt, sichert, daß das Programm die Gesamt-Aufgaben 
des Systems korrekt ausführt. 

Der Entwickler verwendet Simulatoren. Prüfgeräte und verschiedene statistische 
Verfahren, um ein Maß für die Eigenschaften des Programmes zu erhalten. 


Dokumentation ist die Beschreibung des Programmes in 
der geeigneten Form für Anwender und Servicepersonal. 

Dokumentation gestattet auch dem Entwickler eine Pro¬ 
gramm-Bibliothek aufzustellen, so daß später folgende Aufgaben wesentlich 
einfacher sein werden. Flußdiagramme, Kommentare, Speicherpläne und eine 
Bibliothek bilden einige der Hilfsmittel, die bei der Dokumentation verwendet 
werden 


DOKUMEN¬ 

TATION 


Beispiele von Eingaben sind: 

• Datenblöcke von Übertragungsleitungen 

• Statusworte von peripheren Geräten 

• Daten von A/D-Konvertern 


Dann können wir folgende Fragen über jedes Eingangs- 
Signal aufstellen: 


1) In welcher Form liegt es vor, das heißt, welche Signale wird der Computer 
tatsächlich empfangen? 

2) Wann ist das Eingangssignal verfügbar und wie weiß der Prozessor, daß es 
verfügbar ist? Muß der Prozessor das Eingangssignal mit einem Abtast- 
Signal anfordern? Besitzen die Eingangssignale ihren eigenen Takt? 

3) Wie lange sind die Eingangssignale verfügbar? 

4) Wie oft ändern sie sich und wie weiß der Prozessor, daß sie sich geändert 
haben? 

5) Bestehen die Eingangssignale aus einer Sequenz oder einem Datenblock’ 
Ist die Reihenfolge wichtig? 

6) Was sollte geschehen, wenn die Daten Fehler enthalten? Diese können Über¬ 
tragungsfehler enthalten, falsche Daten, falsche Reihenfolge, zusätzliche 
Daten etc. 

7) Besitzt das Eingangssignal eine Beziehung zu anderen Eingangs- oder Aus¬ 
gangs-Signalen? 


FAKTOREN BEI 
EINGÄNGEN 
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DEFINITION DER AUSGANGS-SIGNALE 

Der nächste Schritt besteht in der Delimtion der Ausgaben. Wir müssen alle 

Ausgangssignale auflisten, die der Computer erzeugen muß. Beispiele von 

Ausgangssignalen beinhalten: 

• Dalenblöcke zu Übertragungsleitungen 

• Steuerworte zu peripheren Bausteinen 

• Daten zu D/A-Wandlern 

Dann können wir folgende Fragen über jedes Ausgangssignal stellen: 

t) In welcher Form liegen sie vor, das heißt, welche Signale muß der 
Computer erzeugen? 

2) Wann müssen sie verfügbar sein, und wie weiß der periphere Baustein, daß 
sie verfügbar sind? 

3) Wie lange müssen sie verfügbar sein? 

4) Wie oft müssen sie geändert werden und wie weiß der periphere Baustein, 
daß sie sich geändert haben? 

5) Liegen die Ausgangssignale in einer bestimmten Reihenfolge vor? Ist die 
Reihenfolge wichtig? 

6) Was sollte geschehen, um Übertragungsfehler zu vermeiden oder Fehler von 
peripheren Bausteinen zu erkennen und zu berichtigen? 

7) Besteht ein Zusammenhang mit anderen Eingangs- und Ausgangs-Signalen? 


VERARBEITUNGS-ABSCHNITT 

Zwischen dem Lesen von Eingangsdaten und dem Senden von Ausgangs- 
Resultaten liegt der Verarbeitungs-Abschnitt. Hier müssen wir exakt bestim¬ 
men, wie der Computer die Eingangsdaten verarbeiten muß. Die Fragen 

sind: 


1) Wie lautet das grundlegende Verfahren (Algorithmus) 
zur Umwandlung von Eingangsdaten in Ausgangs Er¬ 
gebnisse? 

2) Welche zeitlichen Beschränkungen liegen vor? Diese können Datenge¬ 
schwindigkeit. Verzögerungszeiten, die Zeitkonstanten von Eingabe und 
Ausgabe-Bausteinen enthalten etc. 

3) Welche Speicher-Beschränkungen liegen vor? Bestehen Grenzen bei der 
Größe des Programmspeichers oder Datenspeichers, oder bei der Größe 
des Puffers? 

4) Welche Standardprogramme oder Tabellen müssen verwendet werden? Wel¬ 
che Anforderungen bestehen an diese? 

5) Welche speziellen Fälle existieren und wie sollte das Programm diese ver¬ 
arbeiten? 

6) Wie genau müssen die Ergebnisse sein? 

7) Wie sollte das Programm auf Verarbeitungsfehler oder spezielle Be¬ 
dingungen, wie Überlauf, Unterlauf u.ä. reagieren? 


VERHALTEN BEI FEHLERN 

Ein wichtiger Faktor in zahlreichen Anwendungen ist das Verhalten bei Feh¬ 
lern. Natürlich muß der Entwickler Vorsorge treffen, um allgemeine Fehler aufzu¬ 
decken und Fehlfunktionen zu erkennen. Hierzu sind vom Entwickler folgende 
Fragen zu stellen: 

1) Welche Fehler können auftreten? 

2) Welche Fehler sind am wahrscheinlichsten? 

Wenn das System von einer Person bedient 
wird, sind menschliche Fehler am häufigsten. Nach den menschlichen Feh¬ 
lern treten am ehesten Übeitragungsfehler auf, darauf folgen mechanische, 
elektnsche, mathematische oder Verarbeitungsfehler. 

3) Welche Fehler sind im System nicht sofort offensichtlich? Ein spezielles Pro¬ 
blem ist das Auftreten von Fehlern, die vom System oder Bedienenden nicht 
als solche sofort erkennbar sind. 

4) Wie kann sich das System von Fehlern mit einem minimalen Verlust von Zeit 
und Daten wieder erholen, und erkennen, daß ein Fehler aufgetreten ist? 

5) Welche Fehler oder Fehlfunktionen verursachen das gleiche System- 
Verhalten? Wie können diese Fehler oder Fehlfunktionen für Diagnostik¬ 
zwecke unterschieden werden? 

6) Welche Fehler betreffen spezielle Syslemverfahren? Zum Beispiel, erfordern 
Paritätsfehler ein Zurücksenden der Daten? 

Eine andere Frage ist: Wie kann der Servicetechniker systematisch die Quelle 
einer Fehlfunklion finden, ohne ein entsprechender Spezialist zu sein? Hier kön¬ 
nen eingebaute Testprogramme, spezielle Diagnostik- oder Kennzeichen- 
Analyse helfen. 


FAKTOREN DER 
VERARBEITUNG 


FEHLER¬ 

BETRACHTUNGEN 
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MENSCHLICHE FAKTOREN 

Zahlreiche, auf Mikroprozessoren basierende Sy¬ 
steme beinhalten eine Wechselwirkung mit 
dem Menschen. Während des gesamten 
Entwicklungs-Vorganges müssen menschliche 
Faktoren für derartige Systeme in Betracht gezogen werden. Unter den Fra¬ 
gen, die ein Entwickler stellen muß, sind: 

1) Welches Eingabe-Verfahren ist das natürlichste für einen Menschen? 

2) Kann der Bedienende leicht feststellen, wie er die Eingabe Operationen be¬ 
ginnen, fortsetzen und beenden muß? 

3) Wie wird der Bedienende über Prozedur-Fehler und Geräle-Fehlfunktionen 
informiert? 

4) Welche Fehler wird der Bedienende am wahrscheinlichsten machen? 

5) Wie erfährt der Bedienende, daß er Daten falsch eingegeben hat? 

6) Liegen die Anzeigen in einer Form vor, die der Bedienende leicht lesen und 
verstehen kann? 

7) Ist die Reaktion des Systems lürden Bedienenden geeignet? 

8) Ist das System leicht zu bedienen? 

9) Gibt es geeignete Richtlinien für einen unerfahrenen Bedienenden? 

10) Gibt es abgekürzte Verfahren und zusätzliche Optionen für den erfahrenen 
Bedienenden? 

11) Kann der Bedienende immer den Zustand eines Systems nach Unterbrech¬ 
ungen bestimmen oder zurücksetzen? 

Ein System so aufzubauen, daß es von Menschen leicht bedient werden kann, 
ist schwierig. Der Mikroprozessor kann das System leistungsfähiger, flexibler 
und vielseitiger machen. Der Entwickler muß jedoch die menschlichen Gesichts¬ 
punkte berücksichtigen, die den Nutzen und die Attraktivität eines Systems ge¬ 
waltig erhöhen können, sowie die Produktivität des Bedienenden. 
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BEISPIELE 

Reaktion auf einen Schalter 


Bild 13-2 zeigt ein einfaches System, in dem 
das Eingangsignal von einem einfachen einpoli¬ 
gen Schalter (Schließer) kommt und das Aus¬ 
gangssignal zu einer einzelnen LED-Anzeige 
fühlt. Als Reaktion auf ein Schließen des Schal¬ 
ters schaltet der Prozessor die Anzeige eine Se¬ 
kunde lang ein. 

Dieses System sollte leicht zu definieren sein. 


DEFINITION DES 
SCHALTERS-UND 
LAMPENSYSTEMS 

SCHALTER- UND 
LAMPEN-EINGANG 


Wir wollen zuerst das Eingangssignal und die Antwort auf jede vorher aufge¬ 
worfenen Fragen darstellen: 


1) Das Eingangs-Signal stellt ein einzelnes Bit dar das entweder "O” (Schalter 
geschlossen) oder "1" (Schalter offen) ist. 

2) Das Eingangssignal ist immer verfügbar und braucht nicht angefordert zu 
werden. 

3) Das Eingangssignal ist für wenigstens mehrere Millisekunden nach dem 
Schließen verfügbar. 

4) Das Eingangsssignal wird sich selten mehr als einmal innerhalb einiger Se¬ 
kunden ändern. Der Prozessor muß das Prellen des Schalters handhaben 
können. Der Prozessor muß den Schalter überwachen, um zu bestimmen, 
wann er geschlossen ist. 

5) Es gibt keine bestimmte Reihenfolge der Eingangsignale. 

6) Die offensichtlichen Eingangsfehler sind ein Defekt des Schalters, Fehler in 
der Eingangs-Schaltung und der Fall, daß der Bedienende versucht, den 
Schalter zu schließen, bevor ein ausreichendes Zeit-Intervall verstrichen ist. 
Wir werden die Handhabung dieser Fehler später besprechen. 

7) Das Eingangssignal hängt nicht von anderen Eingangs- oder Ausgangs¬ 
signalen ab. 

Der nächste Schritt in der Definition des SCHALTER UND 

Systems besteht im Untersuchen des Ausgangs- LAMPEN-AUS- 

signales. Die Antworten auf diese Fragen sind: GANGSSIGNALE 


1) Das Ausgangssignal ist ein einziges Bit, 
das ’ 0” zum Einschalten der Anzeige, "1" 
zum Ausschalten ist 

2) Es gibt keine zeitlichen Beschränkungen des Ausgangssignales. ier peri¬ 
phere Baustein braucht nicht über die Verfügbarkeil der Daten informiert 
werden 

3) Wenn die Anzeige eine LED ist. müssen die Daten nur für einige wenige Milli¬ 
sekunden mit einer Pulsfrequenz von etwa 100 mal pro Sekunde vorliegen. 
Der Betrachter wird eine kontinuierlich leuchtende Anzeige sehen. 

4) Die Daten müssen sich nach einer Sekunde andern (abschalten). 

5) Es gibt keine Reihenfolge der Ausgangssignale. 

6) Die möglichen Fehler des Ausgangssignales sind ein Defekt der Anzeige und 
ein Fehler in der Ausgangs-Schaltung. 

7) Das Ausgangs-Signal hängt nur von dem Schalter-Eingangs-Signal und der 
Zeit ab 
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Der Verarbeitungs-Abschnitt ist extrem einfach. Sobald der Schalter-Eingang 
logisch "0" wird, schaltet die CPU die Lampe (eine logische "0") eine Sekunde 
lang ein. Es bestehen keinerlei zeitliche oder Speicher-Beschränkungen 

Sehen wir uns nun die möglichen Fehler und HANDHABUNG VON 
Fehlfunktionen an. Diese sind: SCHALTER- UND 

LAMPENFEHLERN 

1) Ein weiteres Schließen des Schalters, bevor 
eine Sekunde verstrichen ist. 

2) Schalter-Fehler. 

3) Anzeige-Fehler. 

4) Computer-Fehler. 

Sicher ist der erste Fehler der wahrscheinlichste Die einfachste Lösung besteht 
für den Prozessor darin, ein Schließen des Schalters zu ignorieren, bis eine Se¬ 
kunde verstrichen ist. Diese kurze zeitliche Periode wird sicher für den Bedie¬ 
nenden schwer erkennbar sein. Ferner bedeutet das Ignorieren des Schalters 
während dieser Periode, daß keine Entpreil-Schaltung oder Software hierfür er¬ 
forderlich ist, da das System in keiner Weise auf das Prellen reagiert 



Bild 13-2. Das Schalter- und Lampen-System 


Offensichtlich können die drei letzten Fehler nicht vorhersehbare Ergebnisse lie¬ 
fern Die Anzeige kann auf Ein bleiben, auf Aus, oder den Zustand willkürlich än¬ 
dern, Einige mögliche Wege zur Isolierung des Fehlers würden sein: 

1) Lampentest-Hardware zur Prüfung der Anzeige, d.h. eine Taste, die die Lam¬ 
pe unabhängig vom Prozessor einschaltet. 

2) Eine direkte Verbindung mit dem Schalter, um seine Arbeitsweise zu prüfen. 

3) Ein Diagnostik-Programm, das die Eingangs- und Ausgangs-Schaltungen 
prüft. 

Wenn sowohl die Anzeige wie der Schalter funktionieren, besitzt der Compu¬ 
ter einen Fehler. Ein Servicetechniker mit entsprechenden Geräten kann die Ur¬ 
sache des Fehlers bestimmen. 
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Ein Speicherlader mit Schaltern 

Bild 13-3 zeigt ein System, mit dem der Anwen- DEFINIEREN EINES 

der Daten in jeden Speicherplatz in einem Mi- SPEICHERLADERS 

krocomputer eingeben kann. Ein Eingangsport, MIT SCHALTERN 

DPORT, liest Daten von acht Kippschaltern. 

Der andere Eingangsport, CPORT, wird zum Lesen von Steuer-Informationen 
verwendet. Es gibt drei Moment-Schalter: Hohe Adresse, niedrige Adresse und 
Daten. 

Das Ausgangs-Signal ist der Wert der letzten vollständigen Eingabe von den 
Datenschaltern. Es werden acht LEDs für die Anzeige verwendet. 

Das System wird natürlich außerdem verschiedene Widerstände, Puffer und 
Treiber benötigen. 

Wir werden zuerst die Eingangssignale prüfen. Die Eigenschaften der Schalter 
sind die gleichen wie im vorhergehenden Beispiel Es gibt jedoch eine be¬ 
stimmte Reihenfolge der Eingangssignale: 

1) Der Bedienende muß die Datenschalter entsprechend der acht höchsten Bits 
einer Adresse setzen, dann 

2) den Schalter "Höhe-Adresse' 1 drücken Die hohen Adressen-Bits werden auf 
den Lampen aufscheinen und das Programm wird die Daten als das hohe 
Byte der Adresse interpretieren 

3) Dann muß der Bedienende die Datenschalter auf den Wert des niedrigstwer¬ 
tigen Bytes der Adresse stellen und 

4) die Taste "Niedrige-Adresse” drücken Die niedrigen Adressenbits werden 
auf den Lampen aufscheinen und das Programm wird die Daten als das nied- 
nge Byte der Adresse ansehen. 

5) Schließlich muß der Bedienende die gewünschten Daten auf den Datenschal¬ 
tern emstellen und 

6) den Schalter "Daten" drücken. Die Anzeige wird nun die Daten zeigen und 
das Programm speichert die Daten in den Speicher an den vorher eingege¬ 
benen Adressen. 

Der Bedienende kann den Vorgang zur Eingabe eines ganzen Programmes wie¬ 
derholen. Natürlich haben wir auch in dieser vereinfachten Situation zahlreiche 
mögliche Sequenzen zu betrachten. Wie können wir mit fehlerhaften Sequenzen 
fertig werden und das System leicht zu bedienen machen? 

Die Ausgabe ist kein Problem. Nach Jeder Eingabe sendet das Programm das 
Komplement der Eingangs-Bits zu den Anzeigen (da die Anzeigen aktiv low 

sind). Die Ausgangsdaten verbleiben unverändert, bis zur nächsten Eingabe- 
Operation. 

Der Verarbeitungs-Abschnitt bleibt ziemlich einfach. Es gibt keine zeitlichen 
oder Speicher-Beschränkungen. Das Programm kann die Schalter entprellen, 
indem es einige wenige Millisekunden wartet und muß dann die komplementier¬ 
ten Daten zu den Anzeigen liefern. 
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Die wahrscheinlichsten Fehler sind Irrtümer des Bedienen¬ 
den. Diese beinhalten: 

1) Falsche Eingaben 

2) Falsche Reihenfolge 

3) Unvollständige Eingaben, z.B. Vergessen von Daten. 

Das System muß imstande sein, diese Probleme in einer vernünftigen Weise zu 
handhaben, da sie im tatsächlichen Betneb mit Sicherheit auftreten. 

Der Entwickler muß auch die Einflüsse von Fehlern des Gerätes beachten. So 

wie vorher sind die möglichen Schwiengkeiten: 

1) Schalter-Fehler 

2) Anzeige-Fehler 

3) Computer-Fehler 


HANDHABUNG 
DER FEHLER 
DES SPEICHER¬ 
LADERS 
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Bild 13-3. Der Speicher-Lader mit Schaltern. 


13-12 


13-13 





in diesem System müssen wir jedoch mehr Aufmerksamkeit der Tatsache 
schenken, wie diese Fehler das System beeinflussen. Ein Computer-Fehler wird 
wahrscheinlich ein sehr ungewöhnliches Verhalten des Systems bewirken, und 
wird leicht festzustellen sein. Ein Anzeige-Fehler kann nicht unmittelbar erkenn¬ 
bar sein. Hier würde die Möglichkeit eines Lampentests dem Bedienenden ge¬ 
statten, ihr Funktionieren zu überprüfen. Beachten Sie. daß wir jede LEO separat 
testen wollen, um den Fall zu erkennen, bei dem Ausgangsleitungen gegenein¬ 
ander kurzgeschlossen sind. Zusätzlich könnte der Bedienende nicht unmittel¬ 
bar Schalter-Fehler feststellen. Jedoch sollte der Bedienende sie bald erkennen 
und durch ein Verfahren der Elimination feststellen, welcher Schalter defekt ist. 

Sehen wir uns einige der möglichen Fehler des 
Operators an. Typische Fehler würden sein: 

1) Falsche Daten 

2) Falsche Reihenfolge der Eingaben oder Schal¬ 
ter 

3) Versuch, neue Eingaben durchzuführen, ohne 
vollständige Eingabe der Laufenden. 

Der Bedienende wird wahrscheinlich Fehler bemerken, sobald sie auf den An¬ 
zeigen aufscheinen. Was wäre ein annehmbares Verfahren für den Bedienen¬ 
den? Einige der Möglichkeiten sind: 

1) Der Bedienende muß das Eingabe-Verfahren abschließen, d h. die niedrigen 
Adressen und Daten eingeben, wenn der Fehler in den hohen Adressen auf- 
tritt. Natürlich ist dieses Verfahren mühsam und würde nur dazu dienen, den 
Bedienenden zu verärgern. 

2) Der Bedienende muß den Eingabe Prozess neu starten, indem er zu den Ein¬ 
gabe-Schritten für die hohe Adresse zurückkehrt. Diese Lösung ist nützlich, 
wenn der Fehler in den hohen Adressen auftrat, zwingt jedoch den Bedienen¬ 
den frühere Daten wieder einzugeben, wenn sich der Fehler in den niedrigen 
Adressen-oder Datenstufen befunden hat. 

3) Der Bedienende kann jeden Teil der Sequenz zu jeder Zeit eingeben, indem 
er einfach die Datenschalter auf die gewünschten Daten stellt und die ent¬ 
sprechende Taste drückt. Dieses Verfahren gestattet dem Bedienenden. Kor¬ 
rekturen an jedem Punkt der Sequenz auszuführen 

Diese Verfahren sollte immer lenem vorgezogen werden, das keine unmittelbare 
Fehlerkorrektur gestatten, aus einer Vielzahl von abschließenden Schritten be¬ 
steht, oder Daten in das System eingibt, ohne dem Bedienenden einen Ab¬ 
schlußtest zu gestatten. Jede zusätzliche Komplikation in der Hardware oder 
Sottware wird durch eine erhöhte Effizienz des Bedienenden belohnt. Sie sollten 
immer den Mikrocomputer die mühsame Arbeit ausführen lassen und das Er¬ 
kennen willkürlicher Sequenzen gestatten. Er wird niemals müde und vergißt 
niemals, was sich im Bedienungshandbuch befand. 

Eine weitere nützliche Eigenschaft wären Status-Lampen, die die Bedeutung der 
Anzeige definiert. Drei Status-Lampen, markiert mit "Hohe Adresse", "Niedrige 
Adresse" und "Daten", würden dem Bedienenden wissen lassen, was er einge 
geben hat und er sich nicht merken muß, welche Tasten er gedrückt hat. Der 
Prozessor müsste die Sequenz überwachen, jedoch die zusätzliche Komplika¬ 
tion in der Software würde die Aufgabe des Bedienenden sehr vereinfachen. 
Natürlich würden drei getrennte Sätze von Anzeigen plus der Möglichkeit des 
Prüfens eines Speicherplatzes noch nützlicher für den Bedienenden sein. 


KORREKTUR DER 
FEHLER DES 
BEDIENENDEN BEIM 
SPEICHERLADER 


Wir sollten beachten, daß, obwohl wir die Wechselwirkung mit dem Bedienen¬ 
den hervorgehoben haben, die Maschinen- oder System-Wechselwirkung zahl¬ 
reiche gleiche Eigenschaften besitzt. Der Mikroprozessor sollte die Arbeit aus¬ 
führen. Wenn durch Komplizierung der Aufgabe des Mikroprozessors das Auf¬ 
decken von Fehlern einfacher gemacht und die Ursachen der Fehler verdeut¬ 
licht werden, wird das ganze System besser arbeiten und leichter zu warten 
sein. Beachten Sie, daß Sie Überlegungen über die Verwendung des Systems 
und den Service nicht erst am Ende des Software-Entwicklungsprozesses ma¬ 
chen sollten. Stattdessen sollten Sie diese bereits in der Detinitions-Phase an¬ 
stellen. 


Ein Verifikations-Terminal 

Bild 13-4 ist ein Blockschaltbild eines einfachen 
Kreditkarten-Überprüfungs-Terminals. Ein Ein¬ 
gangsport leitet Daten von einer Tastatur her 
(siehe Bild 13-5), der andere Eingangsport 
nimmt Verifikations-Daten von einer Übertra¬ 
gungsleitung auf. 

Ein Ausgangspoit sendet Daten zu einem Satz von Anzeigen (siehe Bild 13-6). 
Ein anderer sendet die Kreditkarten-Nummer zum Zentralcomputer. Ein dritter 
Ausgangsport schaltet eine Lampe ein, wann immer das Terminal bereit zur 
Aufnahme einer Anfrage ist, eine andere Lampe, wenn der Bedienende die In¬ 
formation sendet. Die "BELEGT"'-Lampe wird abgeschaltet, wenn die Antwort 
zurück kommt. Natürlich wird die Eingabe und die Ausgabe von Daten komplex¬ 
er als im vorhergehenden Fall sein, obwohl die Verarbeitung noch ziemlich ein¬ 
fach ist. 

Zusätzliche Anzeigen können sehr nützlich sein, um die Bedeutung der Ant¬ 
wort hervorzuheben. Zahlreiche Terminals verwenden ein grünes Licht für "Ja" 
ein rotes Licht für "Nein" und ein gelbes Licht für "beim Manager rückfragen". 
Beachten Sie, daß diese Lampen deutlich mit ihrer Bedeutung zu kennzeich¬ 
nen sind, um auch mit der Situation fertig zu werden, bei der der Bedienende 
farbenblind ist. 

Sehen wir uns zuerst das Tastatur-Eingangs- 
Signal an. Dieses ist natürlich verschieden von 
Schalter-Eingangs-Signalen, da die CPU irgend¬ 
eine Möglichkeit besitzten muß. neue Daten zu 
unterscheiden. Wir wollen annehmen, daß jedes 
Schließen einer Taste einen eindeutigen Hexadezimal-Code liefert (wir können 
alle Tasten in eine Ziffer codieren, da es zwölf Tasten gibt) und einen Abtast- 
Impuls. Das Programm wird den Abtast-Impuls zu erkennen haben und muß 
die Hexadezimalzahl holen, die die Taste identifiziert. Es gibt hier eine zeitliche 
Einschränkung, da das Programm keine Daten oder Abtast-Impulse auslassen 
darf. Die Beschränkung ist nicht schwerwiegend, da Tastatur-Eingaben wenig¬ 
stens einige Millisekunden voneinander entfernt sind. 


EINGÄNGE ZUM 
VERIFIKATIONS¬ 
TERMINAL 


DEFINITION EINES 
VERIFIKATIONS¬ 
TERMINALS 
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Das Übertragungs-Eingangssignal besteht ähnlich aus einer Serie von Zei¬ 
chen, von dene jedes durch einen Abtast-Impuls identifiziert wird (vielleicht 
von einem UART). Das Programm wird jeden Abtast-Impuls zu erkennen haben 
und das Zeichen holen müssen. Die Daten, die über die Übertragungs- 
leitung gesendet werden, sind gewöhnlich in Nachrichten organisiert. Eine 
mögliche Nachrichten-Form ist: 

1) Einführungszeichen, oder Nachrichten-Kopf (Header) 

2) Bestimmungs-Adresse des Terminals. 

3) Codiert es Ja oder Nein. 

4) Abschlußzeichen (Trailer). 

Das Terminal wird den Nachrichten-Kopf prüfen, die Bestimmungs-Adresse le¬ 
sen und feststellen, ob die Nachricht für das Terminal vorgesehen ist. Wenn die 
Nachricht für das Terminal bestimmt ist, nimmt das Terminal die Daten an. Die 
Adresse könnte (und dies ist häufig der Fall) im Terminal fest verdrahtet sein, so 
daß das Terminal nur für dieses bestimmte Nachrichten empfängt. Diese Lö¬ 
sung vereinfacht die Software auf Kosten einiger Flexibilität. 

Das Ausgangssignal ist komplexer als in den 
früheren Beispielen. Wenn die Anzeigen gemul- 
tiplext werden, muß der Prozessor nicht nur die 
Daten zum Anzeige-Port senden, sondern muß 
auch die Daten zu einer bestimmten Anzeige 
leiten. 

Wir werden entweder einen separaten Steuerport oder einen Zähler und Deco¬ 
der hierfür benötigen. Beachten Sie, daß Hardware-Steuerungen führende Nul¬ 
len so lange ausblenden können, wie die erste Stelle in einer mehrstelligen Zahl 
niemals null ist. Die Software kann diese Aufgabe ebenfalls übernehmen. Zeitli¬ 
che Einschränkungen beinhalten die Impulslänge und Frequenz, die zur Erzeu¬ 
gung einer scheinbar kontinuierlichen Anzeige für den Bedienenden erforderlich 
ist. 

Das Kommunikations-Ausgangs-Signal besteht aus einer Serie von Zeichen 
mit einem speziellen Format. Das Programm wird auch die zwischen den Zei¬ 
chen erforderliche Zeit zu berücksichtigen haben. Ein mögliches Format für die 
Ausgangs-Nachricht ist: 

1) Nachrichten-Kopf (Header) 

2) Terminal Adresse 

3) Kreditkarten-Nummer 

4) Abschluß-Zeichen (Trailer) 


AUSGANGSSIGNALE 
DES VERIFIKATIONS¬ 
TERMINALS 



Bild 13-4, Blockschaltbild des Kreditüberprüfungs-Terminals, 
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Oie Zitlem-Testen gestatten Ziffern-Eingaben 
LÖSCHEN enflerri die gesamte Eingabe 
SENDEN überträgt die Eingabe zum Zential-Compuler 


Bild 13-5 Tastatur für das Kreditüberprüfungs-Terminal 
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Bild 1 3-6. Anzeige für das Kreditüberprüfungs-Terminal. 


Ein zentraler Kommunikationscomputer kann zur Abfrage (polling) der Termi¬ 
nals verwendet werden, der prüft, ob Daten zum Senden bereit sind. 

Die Verarbeitung in diesem System beinhaltet zahlreiche neue Aufgaben wie 
etwa: 


1) Identifizierung der Steuertasten durch eine Zahl und Ausführung der ent¬ 
sprechenden Tätigkeiten. 

2) Hinzufügen des Kopf- und Abschlußzeichens für die abgehende Nachricht 

3) Erkennen des Kopf- und Abschlußzeichens in der zurückkehrenden Nach¬ 
richt. 

4} Prüfen der ankommenden Terminal-Adresse. 


Beachten Sie, daß keine der Aufgaben irgendwel¬ 
che komplexe Arithmetik beinhaltet oder irgend¬ 
welche schwerwiegende zeitliche oder Speicher- 
Beschränkungen. 


FEHLER¬ 
HANDHABUNG BEIM 
VERIFIKATIONS¬ 
TERMINAL 


Die Anzahl der möglichen Fehler in diesem System ist natürlich viel größer als 
in den vorhergehenden Beispielen. Wir wollen zuerst die möglichen Fehler des 
Bedienenden betrachten. 

Diese beinhalten: 


1) Falsche Eingabe der Kreditkarten-Nummer. 

2) Versuch des Sendens einer unvollständigen Kreditkarten-Nummer. 

3) Versuch des Sendens einer weiteren Zahl, während der Zentralcomputer be¬ 
reits eine verarbeitet 

4) Löschen nicht existierender Eingaben 
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Einigen dieser Fehler kann durch eine korrekte Strukturierung des Programmes 
leicht begegnet werden Zum Beispiel sollte das Programm die Sendetaste nicht 
annehmen, bis die Kreditkarten-Nummer vollständig eigegeben wurde und es 
sollte tegliche zusätzliche Tastatur-Eingaben ignorieren, bis die Antwort vom 
Zentralcomputer zurückkommt. Beachten Sie. daß der Bedienende erkennen 
will, daß die Eingabe nicht gesendet wurde, da die Besetzt-Lampe nicht leuch¬ 
tet. Der Bedienende wird auch wissen wollen, wann die Tastatur abgeschaltet 
war (wenn das Programm die Tastatur-Eingaben ignoriert), da die Eingaben 
nicht auf der Anzeige aufscheinen und die Bereit-Lampe aus sein wird. 

Falsche Eingaben sind ein offensichtliches Pro- KORRIGIEREN 

blem. Wenn der Bedienende einen Fehler erkannt VON TASTATUR- 

hat, kann er oder sie die Löschtaste veiwenden. FEHLERN 

um Korrekturen auszulühren. - 

Der Bedienende würde es wahrscheinlich bequemer finden, zwei Löschtasten 
zu haben, von denen eine die letzte Eingabe löscht und eine andere die gesam¬ 
te Eingabe Dies würde sowohl die Situation, in der der Bedienende den Fehler 
unmittelbar erkennt beherrschen, sowie die Situation, in der der Bedienende 
den Fehler relativ spät erkennt. Der Bedienende sollte imstande sein, Fehler un¬ 
mittelbar zu korrigieren und möglichst wenige Tasten zu wiederholen haben. 
Der Bedienende wird jedoch eine bestimmte Anzahl von Fehlern machen, ohne 
sie zu erkennen. Die meisten Kreditkarten-Nummern enthalten eine selbst-prüf- 
ende Zahl Das Terminal könnte die Zahlen prüfen, bevor es ein Senden zum 
Zentralcomputer gestattet. Dieser Schritt würde den Zentralcomputer davor be¬ 
wahren, wertvolle Verarbeitungszeit beim Prüfen der Zahl zu verschwenden. 

Dies erfordert jedoch, daß das Terminal über Mittel verfügt, den Bedienenden 
über den Fehler zu informieren, vielleicht durch Blinken einer der Anzeigen oder 
durch einen anderen speziellen Anzeiger, den der Bedienende sicher bemerken 
kann. 

Ein weiteres Problem liegt noch darin, wie der Bedienende erfährt, daß eine Ein¬ 
gabe verlorenging oder falsch verarbeitet wurde. Einige Terminals sperren ein¬ 
fach nach einer maximalen Zeitverzögerung. Der Bedienende bemerkt, daß die 
Besetzt-Lampe ausgegangen ist, ohne daß eine Antwort empfangen wurde. Es 
wird dann vom Bedienenden erwartet, daß er eine neuerliche Eingabe versucht 
Nach ein oder zwei neuerlichen Eingaben sollte der Bedienende den Fehler der 
Service-Stelle melden. 

Zahlreiche Geräte-Fehler sind ebenfalls möglich. Neben den Anzeigen, Tasta¬ 
tur und Prozessor existiert nun das Problem von Übermittlungs-Fehlern, sowie 
Fehler des Zentralcomputers. 

Die Dalenübertragung muß wahrscheinlich eine Fehlerprüfung und Korrektur- 
Verfahren einschlteßen. Einige Möglichkeiten sind: 
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1) Die Pariläl ermöglicht eine Fehler- 
Feslslellung, jedoch keine Korrektur Der 
Emptanger wird irgendeinen Weg für die An¬ 
forderung einer neuerlichen Übertragung be¬ 
nötigen und der Sender muß eine Kopie der Daten aufbewahren, bis ein ord¬ 
nungsgemäßer Empfang bestätigt wurde. Parilätsprufung ist jedoch leicht zu 
realisieren. 

2) Kurze Mitteilungen können anspruchsvollere Schemas verwenden. Zum Bei¬ 
spiel könnte die Ja/Nein-Antwort zum Terminal so codiert werden, daß sie 
eine Fehler Feststellung und Korrektur-Möglichkeit ergibt- 

3) Eine Bestätigung und eine begrenzte Anzahl neuerlicher Eingaben könnte 
eine Anzeige auslosen, die den Bedienenden über einen Kommunikations¬ 
fehler (Unmöglichkeit zum Transfer einer Nachncht ohne Fehler) oder Com¬ 
puter-Fehler (keine Reaktion aut alle Nachrichten innerhalb einer bestimmten 
Zeilperiode) informieren würde Ein derartiges Schema, zusammen mit dem 
Lampenlest würde eine ziemlich einfache Fehlerdiagnose ermöglichen. 

Eine Anzeige für einen Uberlragungsfehler oder für einen Fehler des Zentral- 
compulers sollte auch das Terminal wieder freigeben, das heißt, eine neuerliche 
Eingabe gestalten. Dies ist erforderlich, wenn das Terminal keine Eingaben an¬ 
nimmt, wahrend eine Überprülung im Gange ist. Das Terminal sollte 
auch nach einer bestimmten maximalen Zeitverzögerung wieder freigegeben 
werden. Bestimmte Eingaben sollten für Diagnose-Zwecke reseiviert werden, 
d.h., bestimmte Kreditkarlen-Zahlen könnten zum Prüfen der internen Arbeits¬ 
weise des Terminals und zum Testen der Anzeigen verwendet werden. 


ÜBERBLICK ÜBER DIE DEFINITION DER AUFGABE 

Aufgaben-Definition ist ein ebenso wichtiger Teil der Software-Entwicklung, 
da es nur eine andere Form der Entwicklungs-Tätigkeit ist. Beachten Sie, daß 
dies keine Programmier-Kenntnisse oder Kenntnis des Computers erfordert. 
Es basiert stattdessen auf einem Verständnis des Systems und einem gesun¬ 
den ingenieur-mäßigen Urteilsvermögen. Mikroprozessoren können eine Flexi¬ 
bilität bieten, die der Entwickler für eine Reihe von Eigenschaften einsetzen 
kann, die früher nicht verfügbar waren. 

Die Aufgaben-Definition ist unabhängig von einem speziellen Computer, Com¬ 
putersprache oder Entwicklungssystem. Sie sollte jedoch die Richtlinien lie¬ 
fern, welche Geschwindigkeit der Computer für eine bestimmte Anwendung 
benötigt, und welche Art von Hardware/Software-Überlegungen der Entwick¬ 
ler anstellen kann. Die Phase der Aufgaben-Definition ist in der Tat unabhän¬ 
gig davon, ob überhaupt ein Computer verwendet wird, obwohl eine Kenntnis 
der Möglichkeiten des Computers dem Entwickler helfen kann, sich ein Bild 
über die möglichen Verfahren zu machen. 


KORREKTUR VON 
ÜBERTRAGUNGS¬ 
FEHLERN 
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PROGRAMM-ENTWICKLUNG 


Programm-Entwicklung ist die Stufe, in der die Aufgaben-Definition in Form ei¬ 
nes Programmes formuliert wird. Wenn das Programm klein und einfach ist, 
kann diese Stufe vielleicht nicht mehr als die Aufstellung eines Flußdiagram- 
mes mit nur einer Seite beinhalten. Wenn das Programm größer oder komple¬ 
xer ist, sollte der Entwickler anspruchsvollere Methoden in Betracht ziehen. 

Wir werden das Aufstellen von Flußdiagrammen, modulare Programmierung, 
strukturierte Programmierung und die sogenanne "Top-Down '-Entwicklung 
(Verfahren der schrittweisen Verfeinerung) besprechen. Wir werden versu¬ 
chen, die Gründe für die Anwendung dieser Methoden aufzuzeigen, sowie ihre 
Vorteile und Nachteile. Wir werden jedoch keine Entscheidung bezüglich einer 
speziellen Methode fallen, da es keinen Grund gibt, daß eme Melhode immer 
allen anderen überlegen ist Sie sollten sich vor Augen halten, daß die Aufgabe 
dann besieht, ein ordnungsgemäß arbeitendes System zu schaffen und nichl 
einseitig einer bestimmten Melhode zu folgen. 

Alle Verfahren besitzen jedoch einige offen¬ 
sichtliche gemeinsame Prinzipien. Viele von die¬ 
sen sind die gleichen Prinzipien, die für jede Art 
einer Entwicklung gelten, wie etwa: 

1) Gehen Sie in kleinen Schnllen vor. Versuchen Sie 
zu erledigen. 

2) Teilen Sie große Aulgaben in kleine logisch getrennte Aufgaben ein Ma¬ 
chen Sie die Unter-Aufgaben soweil wie möglich unabhängig von anderen, 
so daß sie separat gelestel und daher Änderungen ohne Beeinflussung der 
anderen ausgefühd werden können. 

3) Machen Sie den Fluß der Sleuerung so einfach wie möglich, damit Fehler 
leichler aufzufinden sind. 

4) Verwenden Sie so häufig wie möglich bildliche oder gratische Beschrei¬ 
bungen. Man kann sich diese leichter vorstellen als wörtliche Beschreibung. 
Dies ist der große Vorteil von Flußdiagrammen 

5) Achlen Sie vor allem auf Klarheit und Einfachheit Sie können die Eigen- 
schaflen verbessern (falls erforderlich), sobald das System funktioniert 

6) Gehen Sie in gründlicher und syslematischer Weise vor. Verwenden Sie 
Prüflisten und Slandard-Verfahren. 

7) Fordern Sie das Schicksal nichl heraus. Verwenden Sie enlweder nicht 
Melhoden, mil denen Sie nichl völlig verlraul sind, oder verwenden Sie die¬ 
se sehr sorgfältig Achlen Sie auf Silualionen, die Verwirrung hervorrufen 
könnten und klären Sie diese so bald wie möglich. 

8) Beachten Sie, daß im System nach Fehlern gesucht werden muß. dieses ge¬ 
testet und gewaltet werden muß. Planen Sie auch für diese späteren Stufen 

9) Verwenden Sie einfache und gfeichbleibende Terminologie und Methoden. 
Wiederholung ist kein Fehler in der Programm-Entwicklung, noch ist die 
Komplexität eineTugend, 

10) Formulieren Sie die Entwicklung vollständig, bevor Sie mit der Codierung 
beginnen. Widerstehen Sie der Versuchung mit dem Niederschreiben von 
Befehlen zu beginnen Es hat nicht mehr Sinn als eine Teile-Liste aufzustel¬ 
len oder einen Printplan zu zeichnen bevor Sie genau wissen, was in dem 
System alles enthalten ist 

11) Seien Sie besonders sorgfältig bei Faktoren, die sich ändern können. 
Machen Sie wahrscheinliche Änderungen so einfach wie möglich. 


GRUNDLEGENDE 
PRINZIPIEN 
DER PROGRAMM¬ 
ENTWICKLUNG 


nicht zu viel auf einmal 
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AUFSTELLEN VON FLUSSDIAGRAMMEN 


Das Aulstellen von Flußdiagrammen ist sicherlich von allen Programmentwick- 
lungs Verfahren am besten bekannt. Programmierbücher beschreiben, wie Pro¬ 
grammierer zuerst vollständige Flußdiagramme aulstellen und dann mit dem 
Schreiben des tatsächlichen Programmes beginnen. In der Tat arbeiten jedoch 
wenige Programmierer auf diese Weise und das Aulstellen der Flußdiagramme 
wurde häufig mehr zum Spaßgemacht. Wir wollen versuchen, sowohl die Vortei¬ 
le wie die Nachteile von Flußdiagrammen zu beschreiben, und die Rolle dieser 
Technik in der Programm-Entwicklung zu zeigen. 

Der grundlegende Vorteil des Flußdiagrammes VORTEILE VON 
besteht in der bildlichen Darstellung der FLUSSDIAGRAMMEN 
Aufgabe. Häutig findet man. daß derartige Dar¬ 
stellungen mehr aussagen als geschriebene 

Der Entwickler kann sich das gesamte System vorstellen und die Beziehungen 
zwischen den einzelnen Teilen erkennen. Logische Fehler und logische Wider¬ 
sprüche sind olt deutlicher zu erkennen. Im besten Falle ist das Flußdiagramm 
ein Bild des gesamten Systems. 


Einige speziellere Vorteile von Flußdiagrammen sind: 

1) Es existieren Standard-Symbole (siehe Bild 13-7). so daß diese allen Anwen¬ 
dern bekannt sind. 

2) Flußdiagramme können von jedem auch ohne Programmier-Kenntnisse ver¬ 
standen werden. 

3) Flußdiagramme können zur Aufteilung des gesamten Projekts in Unter-Auf¬ 
gaben verwendet werden Das Flußdiagramm kann dann zur Kontrolle des 
gesamten Fortschrittes verwendet werden 

4) Flußdiagramme zeigen die Sequenzen der Operationen und können daher 
eine Hilfe bei der Lokalisierung von Fehlerquellen sein. 

5) Das Aufstellen von Flußdiagrammen ist ein Verfahren, das in weitem Maße 
auch neben der Programmierung verwendet wird. 

Diese Vorteile sind alle wichtig. Es ist keine Fra NACHTEILE DER 
ge, daß das Aufstellen von Flußdiagrammen auch FLUSSDIAGRAMME 
weiterhin eine sehr wesentliche Entwicklungs ~ 

technik ist Aber wir sollten uns auch einige der Nachteile der Flußdiagramme 
als Entwicklungs-Verfahren ansehen, zum Beispiel: 

1) Flußdiagramme sind schwierig zu entwickeln, zu zeichnen oder zu ändern, 
außer in den einfachsten Situationen. 

2) Es gibt keinen einfachen Weg, um ein Flußdiagramm fehlerfrei zu machen 
oder zu testen. 

3) Flußdiagramme können auch verwirrend sein. Entwickler finden es schwierig, 
ein Mittelmaß zwischen der Anzahl der benötigten Details, die ein Flußdia¬ 
gramm wer voll machen, und der Menge, die das Flußdiagramm nur wenig 
besser als eine Programm-Auflistung macht, zu linden. 

4) Flußdiagramme zeigen nur die Programm-Organisation. Sie zeigen nicht die 
Organisation der Daten oder die Struktur der Eingabe/Ausgabe Module. 

5) Flußdiagramme helfen nicht bei Hardware oder zeitlichen Problemen oder 
geben Hinweise, wo diese Probleme auftreten können. 
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Daher ist das Flußdiagramm ein wertvolles Hilfsmittel, das aber nicht weit aus¬ 
gedehnt werden sollte. Flußdiagramme sind nützlich als Programm-Dokumen¬ 
tation, da sie Standardformen besitzen und auch für Nicht-Programmierer ver¬ 
ständlich sind. Als Entwicklungs-Hilfsmittel jedoch können Flußdiagramme 
nicht mehr als eine anfängliche Richtlinie bieten. Der Programmierer kann ein 
detailliertes Flußdiagramm nicht von Fehlem befreien und das Flußdiagramm 
ist manchmal schwieriger aufzustellen als das Programm selbst. 



Bild 13-7. Standard-Symbole für Flußdiagramme. 
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BEISPIELE 

Reaktion auf einen Schalter 


Für diese einfache Aufgabe, bei der ein einzel¬ 
ner Schalter eine Lampe eine Sekunde lang ein¬ 
schaltet, ist ein Flußdiagramm leicht aufzustel¬ 
len. 


FLUSSDIAGRAMM 
DES SCHALTER- UND 
LAMPENSYSTEMS 


In der Tat sind derartige Aufgaben typische Beispiele für Bücher über Flußdia¬ 
gramme, obwohl sie nur einen kleinen Teil der meisten Systeme bilden Die Da¬ 


tenstruktur ist hier so einfach, daß sie sicher ignoriert werden kann 


Bild 13-8 stellt das entsprechende Flußdiagramm dar. Es ist auch nicht schwie¬ 
rig zu entscheiden, wie weit ins Detail gegangen werden soll Das Flußdia¬ 
gramm gibt ein einfaches Bild des Verfahrens, das für jedermann verständlich 
ist. 


Beachten Sie, daß die nützlichsten Flußdiagramme Programm-Variablen igno¬ 
rieren und Fragen direkt stellen können. Natürlich sind hier häufig Kompromisse 
erforderlich. Zwei Arten der Flußdiagramme sind manchmal nützlich: Eine all¬ 
gemeine Version in Alltagssprache, die für Nicht-Programmierer nützlich sein 
wird, und eine Version für Programmierer in Ausdrücken der Programm Varia¬ 
blen, die für andere Programmierer von Nutzen sein werden. 

Eine dritte Art von Flußdiagrammen, ein söge- DATEN- 
nanntes Daten-Flußdiagramm, kann ebenfalls FLUSSDIAGRAMME 
sehr nützlich sein. Dieses Flußdiagramm dient 

als Querverweis für die anderen Flußdiagramme, da es zeigt, wie das Programm 
spezielle Daten-Typen handhabt Gewöhnliche Flußdiagramme zeigen den Ver¬ 
lauf des Programmes, wobei unterschiedliche Arten von Daten an verschiede¬ 
nen Stellen verarbeitet werden Daten-Flußdiagramme zeigen andererseits, wie 
spezielle Arten von Daten das System passieren, und sich von einem Teil des 
Programmes zu einem anderen bewegen. Derartige Flußdiagramme sind sehr 
nützlich bei der Fehlersuche und Wartung, da sich Fehler häufig als falsche Be¬ 
handlung von Daten eiweisen. 
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Bild 13-8. Flußdiagramm der I-Sekunden-Reaktion auf einen Schalter. 
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Der Speicher-Lader mit Schaltern 

Dieses System (beziehen Sie sich auf Bild 1 3-3) 
ist beträchtlich komplexer als das vorhergehende 
Beispiel und enthält wesentlich mehr Entschei¬ 
dungen Das Flußdiagramm (siehe Bild t 3-9) ist 
wesentlich schwieriger aufzustellen und nicht so einfach wie das vorhergehen¬ 
de Beispiel. In diesem Beispiel stossen wir aut das Problem, daß es keine Mög¬ 
lichkeit für Fehlersuche und Testen des Flußdiagrammes gibl 


FLUSSDIAGRAMM 
FÜR DEN 
SPEICHERLADER 
MIT SCHALTERN 


Das Flußdiagramm in Bild 13-9 enthält die Verbesserungen, die wir als Teil der 
Aufgaben-Definition vorgeschlagen haben Offensichtlich beginnt dieses Fluß¬ 
diagramm verwirrend zu werden und verliert seine Vorteile gegenüber einer 
einfachen Beschreibung. Hinzufügen anderer Möglichkeiten, die die Be¬ 
deutung der Eingabe mit Status-Lampen definieren und dem Bedienenden ge¬ 
statten, die Eingabe nach deren Beendigung zu prüfen, würde das Flußdia¬ 
gramm noch komplexer machen. Das Aufstellen des Flußdiagrammes aus einfa¬ 
chen Notizen könnte rasch eine beträchtliche Arbeit werden. Jedoch sobald das 
Programm geschrieben wurde, ist das Flußdiagramm als Dokumentation nütz¬ 
lich. 


Start 



Nein 






Hohes Byle der 
Adresse = 
Schalter 


Niednges ßyle der 
Adresse= 
Schalter 

* 

t 

Lampen = Schalter 


Lampen = Schauer 

f 

t 

Walte 

Entpreii-Zeit 


Warle 

Enlpretl-Zeil 




Daten = 

Schalter 



Landen 

Schalter 


Speichere Daten 
n Adresse 


Waiie 

Enipreil-Zeit 



Bild 13-9. Flußdiagramm des Speicherladers mit Schaltern. 
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Kreditkarten-T erminai 


FLUSSDIAGRAMM 
DER KREDIT¬ 
ÜBERPRÜFUNG 


Bei dieser Anwendung (siehe Biid 13-4 bis 13-6) ÜBERPRÜFUNG 

wird das Flußdiagramm noch wesentlich kom- - 

plexer als bei dem Speicher-Lader mit Schaltern FLUSSDIAGRAMM- 

sein. Hier wäre die beste Möglichkeit, für die [ABSCHNITTE __ 

Abschnitte separate Flußdiagramme aufzustel- 

ien, so daß die Fiußdiagramme noch handlich bieiben. Jedoch das Vorhanden¬ 
sein von Datenstrukturen (wie die mehrstellige Anzeige und die Nachrichten) 
macht die Lücke zwischen dem Flußdiagramm und dem eigentlichen Programm 
noch größer. 

Sehen wir uns einige der Abschnitte an. Biid 13-10 zeigt das Tastatur- 
Eingabe-Verfahren für die Zifferntasten. Das Programm muß die Daten nach je¬ 
der Abtastung holen und die Ziffer in die Anzeige-Anordnung plazieren, wenn 
hier Platz ist. Wenn bereits zehn Ziffern in der Anzeige liegen, ignoriert das Pro¬ 
gramm einfach die Eingabe. 

Das tatsächliche Programmm muß die Anzeigen zur gleichen Zeit handhaben. 
Beachten Sie, daß entweder die Software oder die Hardware den Tastatur-Ab¬ 
tastimpuls de aktivieren muß, nachdem der Prozessor eine Ziffer gelesen hat. 




Lösch« 6ry>3De-A/KMÖr>ur>g 
Ts9*?n-Z^oer = Staf1 de* 
Eiiyjafis-Anordnung 
Tas*efvZ»l«*= B 


Ist 

.Tastatur-Impuls^ 


Ist 

^astatur-Zähtep 


Taste -Tastatur- 
Eingangs-Daten 
(Tasten-Zeiger) - 
Taste 


Tasten-Zetger = 
Tasten-Zeiger +1 
Tasten-Zahler = 
Tasten-Zahler fl 


Bild 13-10. Flußdiagramm des Tastatur-Eingabe-Vorgangs. 
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Bild 13-11 Flußdiagramm des Tastatur-Eingabe-Vorgangs mit SENDE-Taste 


In Biid 13-11 wurde die Sende-Taste hinzugefügt. Diese Taste ist natürlich 
wahlweise. Das Terminal könnte die Daten ebenso senden, wenn der Bedienen¬ 
de die vollständige Zahl eingegeben hat. Dieses Verfahren würde dem Operator 
ledoch keine Möglichkeit geben, die gesamte Eingabe zu prüfen. Das Flußdia¬ 
gramm mit der Sendetaste ist komplexer, da es hier zwei Alternativen gibt: 

1) Wenn der Bedienende nicht zehn Ziffern eingegeben hat. muß das Programm 
die Sendetaste ignorieren und irgendeine andere Taste in die Eingabe plazie¬ 
ren 

2) Wenn der Operator zehn Stellen eingegeben hat, muß das Programm auf die 
Sendetaste reagieren, indem es die Steuerung zur Sende-Routine überträgt 
und alle anderen Tasten ignoriert 

Beachten Sie, daß das Flußdiagramm wesentlich schwieriger zu organisieren 
und zu verfolgen ist Es gibt auch keinen offensichtlichen Weg, um das Flußdia¬ 
gramm zu überprüfen 
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Bild 13-12. Flußdiagramm des Tastatur Eingabe Vorgangs mit Funktions-Tasten. 


Bild 13-12 zeigt das Flußdiagramm des Tastatur-Eingabeprozesses mit allen 
Funktionstasten. In diesem Beispiel ist der Fluß der Steuerung keinesfalls ein¬ 
fach. Offensichtlich sind einige geschriebene Erklärungen erforderlich. Die Or¬ 
ganisation und die Anordnung von komplexen Flußdiagrammen erfordert eine 
sorgfältige Planung. Wir sind dem Vorgang gefolgt, indem wir Eigenschaften 
dem Flußdiagramm einzeln beigefügt haben, aber dies resultiert noch in einer 
beträchtlichen Arbeit für das Neu-Zeichnen. Wieder sollten wir uns daran erin¬ 
nern, daß während des Tastatur-Eingabe Verfahrens das Programm auch die 
Anzeigen auffrischen muß. falls sie gemultiplext sind und nicht durch ein Schie¬ 
beregister oder andere Hardware gesteuert werden. 
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Bild 13-13. Flußdiagramm der Empfangs-Routine. 
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Bild 13-13 ist das Flußdiagramm einer Empfangs-Routine. Wir nehmen an, daß 
die Serien/Parallel-Umwandlung und Fehlerprüfung mit Hardware ausgeführt 
wird (z.B. durch einen UART). Der Prozessor muß: 

1) Nach dem Nachrichten-Kopf Ausschau halten (wir nehmen an, daß es ein 

einzelnes Zeichen ist). . . 

2) Die Bestimmungs-Adresse lesen (wir nehmen an, daß diese drei Zeichen 
lang ist) und sehen, ob die Nachricht für dieses Terminal bestimmt ist, daß 
heißt, ob die drei Zeichen mit der Terminal-Adresse übereinstimmen. 

3) Warten auf das Abschluß-Zeichen. 

4) Wenn die Nachricht für das Terminal bestimmt ist, die Besetzt-Lampe aus¬ 
schalten und zur Antwort-Anzeige-Routine gehen. 

5) Im Falle von Fehlern neuerliche Übertragung anfordern, indem zur RTRAN- 
Routine gegangen wird. 

Diese Routine enthält eine große Anzahl von Entscheidungen und das Flußdia¬ 
gramm ist weder einfach noch übersichtlich. 

Offensichtlich war es ein weiter Weg von dem einfachen Flußdiagramm (Bild 
13-8) des ersten Beispiels. Ein vollständiger Satz von Flußdiagrammen für die¬ 
ses terminal wäre eine gewaltige Aufgabe. Es würde aus mehreren zusam¬ 
menhängenden Tafeln mit einer komplexen Logik bestehen und würde einen 
gewaltigen Arbeitsaufwand erfordern. Derartige Anstrengungen wären ebenso 
schwierig wie ein vorläufiges Programm und nicht so nützlich, da Sie es nicht 
auf dem Computer prüfen könnten. 


MODULARE PROGRAMMIERUNG 

Sobald ein Programm groß und komplex wird, ist ein Flußdiagramm nicht länger 
ein befriedigendes Hilfsmittel für die Entwicklung. Jedoch die Aufgaben-Defini- 
tion und das Flußdiagramm kann Ihnen einige Vorstellung vermitteln, wie das 
Programm in vernünftige Unter-Aufgaben aufgeteilt werden könnte. Die Auftei¬ 
lung der gesamten Aufgabe in Unter-Aufgaben oder Module wird "modulare 
Programmierung” genannt. Natürlich wären die meisten der in den früheren Ka¬ 
piteln vorgestellten Programme typische Module in einem großen Systempro¬ 
gramm. Die Probleme, denen der Entwickler bei der modularen Programmie¬ 
rung gegenübersteht bestehen darin, wie das Programm in Module aufzuteilen 
ist und wie er die Module zusammensetzen soll. 


Die Vorteile der modularen Programmierung sind offen¬ 
sichtlich: 

1) Ein einzelnes Modul ist leichter zu schreiben, fehlerfrei 
zu machen und zu testen als ein ganzes Programm. 

2) Ein Modul ist wahrscheinlich an mehreren Stellen nützlich, sowie in anderen 
Programmen, besonders wenn es einigermaßen allgemein aufgebaut ist und 
auch allgemeine Aufgaben ausführt. Sie können sich eine ganze Bibliothek 
von Standard-Modulen aufbauen. 

3) Modulare Programmierung gestattet dem Programmierer die Aufteilung von 
Aufgaben und die Verwendung früher geschriebener Programme. 

4) Änderungen können an einem einzelnen Modul leichter ausgeführt werden 
als in dem gesamten System 

5) Fehler können häufig bei einem einzelnen Modul leichter isoliert und besei¬ 
tigt werden. 

6) Modulare Programmierung ergibt eine bessere Vorstellung, wieviel Fort¬ 
schritt erzielt wurde und wieviel Arbeit noch zu erledigen ist. 


Die Idee der modularen Programmierung ist so 
einleuchtend, daß die Nachteile häufig ignoriert 
werden. Diese sind: 


1) Das Zusammensetzen der Module kann häufig ein größeres Problem sein, 
speziell wenn verschiedene Leute die Module geschrieben haben. 

2) Module erfordern eine sehr sorgfältige Dokumentation, da sie andere Teile 
des Programmes beeinflussen können, wie etwa Daten-Strukturen, die von 
allen Modulen verwendet werden. 

3) Das Überprüfen und Beseitigen von Fehlern in separaten Modulen ist schwie¬ 
rig, da andere Module Daten erzeugen können, die von den zu prüfenden 
Modulen verwendet werden, wobei wiederum andere Module die Ergebnisse 
verwenden können. Sie müssen möglicherweise spezielle Programme 
schreiben (genannt "Driver” - Treiber), nur um Datenbeispiele zu erzeugen 
und die Programme zu testen. Diese "Treiber” benötigen einen zusätzlichen 
Programmier-Aufwand, der keinen Beitrag zum Gesamtsystem leistet. 


NACHTEILE DER 

MODULAREN 

PROGRAMMIERUNG 


VORTEILE 
VON MODULA¬ 
RER PROGRAM¬ 
MIERUNG 
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4) Programme können manchmal sehr schwierig auf vernünftige Weise zu un¬ 
terteilen sein. Wenn Sie ein Programm schlecht unterteilen, so wird die Zu¬ 
sammensetzung sehr schwierig, da nahezu alle Fehler und die sich ergebe¬ 
nen Änderungen mehrere Module betreffen werden. 

5) Modulare Programmierung benötigt ott zusätzliche Zeit und Speicher, da se- 
perate Module Funktionen wiederholen können. 

Deshalb besitzt die modulare Programmierung einige Nachteile, wenn sie auch 
eine bestimmte Verbesserung gegenüber dem einfachen Versuch zum Schrei¬ 
ben des gesamten Programmes auf einmal darstellt. 

Wichtige Überlegungen beinhalten die Beschränkung der Menge von Informa¬ 
tionen, die mehrere Module gleichzeitig verarbe iten, wobei Entscheidungen zu 
treffen sind, ob die Änderung in einem einzelnen Modul und der Zugriff eines 
Moduls auf ein anderes beschränkt werden soll.* 


Ein offensichtliches Problem besteht darin, daß 
es keine erprobten systematischen Methoden 
zum Modularisieren von Programmen gibt. Wir 
sollten daher folgende Richtlinien befolgen:* 

1) Module. die sich auf gemeinsame Daten beziehen, sollten Teile des gleichen 
übergeordneten Moduls sein. 

2) Zwei Module, bei denen das erste das zweite verwendet, oder von diesem 
abhängt, jedoch nicht umgekehrt, sollten getrennt werden 

3) Ein Modul das von mehr als einem anderen Modul verwendet wird, sollte 
eher Teil eines unterschiedlichen übergeordneten Moduls sein, als Teil von 
anderen. 

4) Zwei Module, bei denen das erste von mehreren anderen Modulen und das 
zweite von wenigen anderen Modulen verwendet wird, sollten voneinander 
getrennt werden, 

5) Zwei Module, deren Häufigkeit der Verwendung sich wesentlich voneinander 
unterscheiden, sollten Teil verschiedener Module sein. 

6) Die Struktur oder Organisation von verwendeten Daten sollten in einem ein¬ 
zelnen Modul enthalten sein. 

Wenn ein Programm schwierig zu modularisieren ist, können Sie eventuell die 
entsprechenden Aufgaben neu definieren. Zu viele spezielle Fälle oder zu viele 
Variablen, die spezielle Verarbeitung erfordern, sind typische Beispiele für 
eine unzureichende Aufgaben-Definition. 


BEISPIELE 

Reaktion auf einen Schalter 


Dieses einfache Programm kann in zwei Module 
aufgeteilt werden: 

Modul 1 wartet auf das Einschalten des Schal¬ 
ters und schaltet als Reaktion hierauf die Lampe 
ein. 

Modul 2 liefert die Verzögerung für 1 Sekunde. 

Modul 1 ist wahrscheinlich sehr speziell lür dieses System, da es davon ab¬ 
hangt, wie der Schalter und die Lampe angeschlossen ist Modul 2 wird allge¬ 
mein verwendbar sein, da zahlreiche Aufgaben Verzögerungen benötigen 
Natürlich wäre es sehr vorteilhaft, ein Standard Verzögerungsmodul zu besit¬ 
zen, das Verzögerungen unterschiedlicher Länge liefern könnte. Das Modul be¬ 
nötigt eine sorgldtige Dokumentation, so daß Sie wissen, wie die Länge der 
Verzögerung zu spezifizieren ist, wie das Modul aufzurufen ist und welche Regi¬ 
ster und Speicherplätze das Modul beeinflußt. 

Eine allgemeine Version von Modul 1 wäre weit weniger nützlich, da Sie immer 
mit verschiedenen Arten und Verbindungen von Schaltern und Lampen zu tun 
haben werden. 

Sie werden es wahrscheinlich einfacher finden, ein Modul für eine spezielle Kon¬ 
figuration von Schaltern und Lampen zu schreiben, als den Versuch zu unter¬ 
nehmen, eine Standard-Routine zu verwenden. Beachten Sie den Unterschied 
zwischen dieser Situation und Modul 2. 


Der Speicher-Lader mit Schaltern 


Der Speicher-Lader mit Schaltern ist schwierig 
zu modularisieren, da alle Programm-Aufgaben 
von der Hardware-Konfiguration abhängen und 
die Aufgaben zu einfach sind, daß Module wert¬ 
voll erscheinen. 

Das Flußdiagramm in Bild 13-9 könnte darauf hindeuten, daß ein Modul dasjeni¬ 
ge wäre, das darauf wartet, daß der Bedienende eine der drei Drucktasten betä¬ 
tigt. 

Einige andere Module könnten sein: 


GRUNDLAGEN DER 
MODULARISIERUNG 


MODULARISIERUNG 
DES SCHALTER- UND 
LAMPENSYSTEMS 


MODULARISIERUNG 
DES SPEICHER-LADERS 
MIT SCHALTERN 


) Ein Verzögerungs-Modul, das die erforderliche Verzögerung zum Entprellen 
der Schalter liefert. 

2) Ein Schalter- und Anzeige-Modul, das die Daten von den Schaltern liest und 
sie zu den Anzeigen sendet. 

3) Ein Lampentest-Modul. 

Module, die in hohem Maße von dem System abhängen, wie die beiden letzten, 
smd wahrscheinlich kaum von allgemeinem Nutzen Bei diesem Beispiel würde 
die modulare Programmierung keine großen Vorteile bringen. 
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Das Verifikations-Terminal 


Das Verifikations-Terminal andererseits ist sehr 
gut für modulare Programmierung geeignet. Das 
gesamte System kann sehr einfach in drei 
Hauptmodule unterteilt werden: 

1) Tastatur-und Anzeige-Modul. 

2) Datenübertragungs-Modul. 

3) Datenemptangs-Modul. 

Ein allgemeines Tastatur- und Anzeige-Modul könnte Verwendung in zahlrei¬ 
chen Systemen mit Tastaturen und Anzeigen linden, die Unter-Module wür¬ 
den Aufgaben wie etwa folgende ausführen: 

1) Erkennen einer neuen Tastatur-Eingabe und Holen der Daten. 

2) Löschen der Anordnung als Reaktion auf ein Tasten-Löschen. 

3) Eingabe von Ziffern in den Speicher. 

4) Ausschau halten nach dem Abschluß-Zeichen oder der Sende-Taste. 

5) Anzeige der Ziffern. 

Obwohl die Tasien-Interpretationen und die Anzahl der Stellen variieren werden, 
sind die grundlegenden Vorgänge der Eingabe, Datenspeicherung und Daten- 
Anzeige für zahlreiche Programme gleich. Tasten-Funktionen wie "Löschen" 
wären ebenfalls Standard. Natürlich muß der Entwickler überlegen, welche Mo- 
dule in anderen Anwendungen von Nutzen sein könnten und diesen Modulen 
besondere Aufmerksamkeit schenken. 

Das Datenübertragungs-Modul könnte ebenfalls in Unter-Module aufgeteilt wer¬ 
den wie: 

1) Hinzufügendes Nachrichten-Kopfes (Header). 

2) Übertragung von Zeichen, wie sie die Ausgangsleitung verarbeiten kann 

3) Erzeugen von Verzögerungen zwischen Bits oder Zeichen. 

4) Hinzufügen des Abschluß-Zeichens (Trailer). 

5) Prüfen auf Übertragungsfehler, d h., keine Quittierung oder keine Möglichkeit 
eines Senden mit Fehler. 

Das Daten-Empfangsmodul könnte folgende Untermoduleenthalten 

1) Ausschau halten nach dem Nachrichtenkopf-Zeichen. 

2) Überprüfen der Bestimmungsadresse der Nachncht gegenüber der Terminal- 
Adresse. 

3) Speichern und Interpretieren der Nachricht. 

4) Ausschau halten nach dem Abschluß-Zeichen. 

5) Erzeugen von Bit- oder Zeichen-Verzögerungen. 


MODULARISIERUNG 
DES VERIFIKATIONS¬ 
TERMINALS 


Beachten Sie wie wichtig es hier ist, daß jede Ent¬ 
wicklungs-Entscheidung (wie die Bit Rate, Nach¬ 
richten-Format. oder Fehlerpruf-Verfahren) in nur 
einem Modul enthalten ist. Eine Änderung in 
einer dieser Entscheidungen wird dann nur 
Änderungen in diesem einzelnen Modul erfor 
dem Die anderen Module sollten so geschneben werden, daß sie völlig 
unabhängig von den gewählten Werten oder Methoden sind, die in dem betref¬ 
fenden Modul verwendet werden. Ein wichtiges Konzept ist hier das Prin¬ 
zip von Pamas "information-hiding" (=etwa: Verbergen oder Verhüllen von Infor¬ 
mationen) 1 2 3 4 5 wobei sich die Module nur Informationen teilen, die absolut notwen¬ 
dig zur Durchführung der Aufgabe sind. Andere Informationen sind innerhalb ei¬ 
nes einzelnen Moduls "eingeschlossen". 

Bei der Handhabung von Fehlern sollte dieses Prinzip angewendet werden. 
Wenn ein Modul einen tödlichen Fehler entdeckt, sollte es nicht versuchen, die¬ 
sen zu handhaben. Stattdessen sollte es das aufrufende Modul über den Fehler¬ 
status informieren und diesem Modul die Entscheidung überlassen, wie weiter 
fortzufahren ist Der Grund hierfür ist, daß das untergeordnete Modul häufig 
über zu wenig Informationen verfügt, um entsprechende Verfahren einzuleiten. 
Nehmen Sie beispielsweise an, daß das niederwertige Modul numerische Einga¬ 
ben von einem Anwender aufnimmt. Dieses Modul erwartet eine Reihe von nu¬ 
merischen Daten, abgeschlossen durch ein Camage-Return. Die Eingabe eines 
nicht-numerischen Zeichens bewirkt, daß auf abnormale Weise abgeschlossen 
wird. Da das Modul den Zusammenhang nicht kennt (d.h. ist die numensche 
Reihe ein Operand, eine Zeilen-Nummer, die Nummer einer E/A-Einheit oder die 
Länge einer Datei?), kann es nicht entscheiden, wie mit diesen Fehlern zu ver¬ 
fahren ist. Wenn ein Modul immer selbst versuchen würde, diesen Fehler zu 
beseitigen, würde es seine universelle Verwendbarkeit verlieren und nur in je¬ 
nen Situationen von Nutzen sein, in der gerade dieses Verfahren erforderlich ist 


PRINZIP DES 

DEFINfTIONS- 

HIDING 
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ÜBERBLICK ÜBER MODULARE PROGRAMMIERUNG 


Modulare Programmierung kann sehr nützlich 

sein, wenn Sie folgende Regeln beachten: 

1) Verwenden Sie Module mit 20 bis 50 Zeilen. 

Kürzere Module sind häufig eine Zeitverschwendung, während längere Mo¬ 
dule selten universell und schwierig zu integneren sind. 

2) Versuchen Sie, die Module einigermaßen universell zu machen. Unterschei- 
den Sie zwischen allgemeinen Eigenschaften, wie ASCII-Code oder asyn¬ 
chrone Übertragungs-Formate, die für zahlreiche Anwendungen und Tasten¬ 
identifikationen gleich sein werden, sowie der Anzahl der Anzeigen oder An¬ 
zahl der Zeichen in einer Nachricht, die wahrscheinlich einmalig in einer be¬ 
stimmten Anwendung Vorkommen. Machen Sie das Ändern letzterer Para¬ 
meter einfach Größere Änderungen, wie unterschiedliche Zeichencodes, 
sollten von separaten Modulen gehandhabt werden 

3) Nehmen Sie sich besonders Zeit für Module wie Anzeigen, Anzeigen-Ver- 
arbeitung, Tastatur-Bedienung etc., die in anderen Projekten oder in zahl¬ 
reichen Stellen des momentanen Programmes nützlich sein werden. 

4) Versuchen Sie die Module so ausgeprägt und logisch getrennt wie möglich 
zu halten. 

5} Versuchen Sie nicht, einfache Aufgaben zu modularisieren, bei denen ein 
Neuschreiben der geamten Aufgabe einfacher sein kann, als ein Assemblie- 
ren oder Modifizieren des Moduls 


STRUKTURIERTE PROGRAMMIERUNG 

Wie gehen Sie vor, um Module scharf abgegrenzt zu halten und eine Wech¬ 
selwirkung mit anderen zu vermeiden? Wie schreiben Sie ein Programm, 
das eine klare Sequenz von Operationen besitzt, so daß Sie Fehler aufspü¬ 
ren und korrigieren können? Eine Antwort ist die Verwendung eines Verfah¬ 
rens, bekannt als "strukturierte Programmierung", wobei jeder Teil des Pro¬ 
grammes aus Elementen eines begrenzten Satzes von Strukturen besteht und 
jede Struktur einen einzigen Eingang und einen einzigen Ausgang besitzt. 

Bild 13-14 zeigt ein Flußdiagramm eines nicht strukturierten Programmes. 
Wenn ein Fehler im Modul B auftrilt, haben wir fünf mögliche Quellen für die¬ 
sen Fehler. Wir müssen nicht nur jede mögliche Sequenz überprüfen, son¬ 
dern wir müssen uns auch vergewissern, daß jede Änderung, die zur Korrek¬ 
tur eines Fehlers gemacht wird, nicht eine der anderen Sequenzen beein¬ 
flußt. Das übliche Ergebnis ist. daß eine derartige Beseitigung von Fehlern 
einem Kampf mit einem Karaken ähnelt. Jedesmal, wenn Sie glauben, die Si¬ 
tuation unter Kontrolle zu haben, begegnen Sie einem weiteren Arm. 

Oie Antwort auf dieses Problem ist die Einrich¬ 
tung einer klaren Sequenz von Operationen, 
so daß Sie Fehler isolieren können. Eine klare 
Sequenz verwendet Module mit einem einzi¬ 
gen Eingang und einen einzigen Ausgang. Als 
grundlegende Module sind erforderlich: 


GRUNDLEGENDE 
STRUKTUREN DER 
STRUKTURIERTEN 
PROGRAMMIERUNG 


REGELN FÜR 

MODULARE 

PROGRAMMIERUNG 


1) Eine normale Sequenz, das heißt, eine lineare Struktur, in der die Anwei¬ 
sungen oder Slrukturen nacheinander ausgeführt werden. In der Sequenz. 

51 

52 

53 

führt der Computer zuerst S1 dann S2 und als dnttes S3 aus. S1, S2 und 
S3 können einzelne Befehle oder ein ganzes Programm sein 

2) Eine bedingte Struktur. 

Eine gebräuchliche Struktur wäre "wenn C dann S1. sonsl S2". wobei C eine 
Bedingung ist und S1 und S2 Anweisungen oder Sequenzen. Der Cmputer 
fuhrt S1 aus. wenn C wahr ist und S2. wenn C falsch ist Bild 13-15 zeigt die 
Logik dieser Slruktur. Beachten Sie. daß die Struktur einen einzigen Eingang 
und emen einzigen Ausgang besitzt. Es gibt keinen Weg in S1 Oders2einzu¬ 
treten oder es zu verlassen, außerdurch die Struktur. 

3) Eine Schleifenstruktur. 

Die gebräuchliche Schleifenstruktur ist "erledige S solange C", wobei C eine 
Bedingung ist und S eine Anweisung oder eine Sequenz von Anweisungen. 
Der Computer prüf) C und führt S aus, wenn C wahr ist Diese Struktur (siehe 
Bild 13-16) besitzt ebenfalls einen einzigen Eingang und einen emzigen Aus¬ 
gang. Beachten Sie, daß der Computer S überhaupt nicht ausfuhren wird 
wenn C ursprünglich falsch war. da der Wert von C vor der Ausführung von S 
geprüft wird. 

Bei den meisten strukturierten Programmiersprachen ist eine alternative Schlei- 
lenstruktur vorgesehen. Dieser Aufbau ist bekannt als das sogenannte ’Do- 
until". Sein grundlegender Aufbau ist "do S until C" (führe S aus bis C). wobei C 
eine Bedmgung und S eine Anweisung oder eine Anweisungs Sequenz ist. Sie 
ahneil dem "Do-while"-Aufbau mit der Ausnahme, daß das Prüfen der Schleifen- 
Bedingung C am Ende der Schleife ausgeführt wird. Dadurch wird garantiert, 
daß die Schleife immer wenigstens einmal ausgefühlt wird. Dadurch wird garan¬ 
tiert, daß die Schleife immer wenigstens einmal ausgeführt wird. Dies ist im Fluß¬ 
diagramm in Bild 13-17 dargestellt. Die gemeinsame index-gesteuerte oder DO- 
Schleife kann als ein spezieller Fall einer dieser beiden grundlegenden Schlei- 
fen-Strukturen ausgeführt werden. 
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Bild 13-17. Flußdiagramm der "Do-Untii"-Struktur. 

4) Eine Fall-Slruktur 

Obwohl die "Faii"-Struktur nicht so einfach aufgebaut wie das sequentielle 
"if-then-else" und "do-while” ist, wird sie so häufig gebraucht, daß wir sie hier 
als Ergänzung zu den Beschreibungen der grundlegenden Strukturen hinzu¬ 
fügen wollen. Die Fall Struktur ist ’case I of SO, S1 .... Sn", wobei I ein Index 
und SO, S1,... Sn Anweisungen oder Anweisungs-Sequenzen sind. Wenn I 
gleich 0 ist, dann wird die Anweisung SO ausgeführt, wenn I gleich 1 ist, dann 
wird die Anweisung S1 durchgeführt, etc. Es wird nur eine von n-Anweisun- 
gen ausgeführt Nach seiner Ausführung geht die Steuerung zur nächsten se¬ 
quentiellen Anweisung über, die der Gruppe mit den "Fall-Anweisungen" 
folgt. Wenn I größer als n ist (d.h. die Anzahl der Anweisungen in der "Faii"- 
Anweisung), dann wird keine der Anweisungen in dieser Gruppe ausgeführt 
und die Steuerung geht direkt zur nächsten sequentiellen Anweisung nach 
dieser Gruppe über. Dies wird im Flußdiagramm in Bild 13-18 dargestellt. 
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Bild 13-18 Flußdiagramm der "Case"-Struktur. 


Beachten Sie die folgenden Eigenschaften strukturierter Programmierung: 

1) Es sind nur die drei grundlegenden Strukturen zulässig. 

2 ) Strukturen können auf jede Ebene der Komplexität verschachtelt werden, 
so daß jedes Programm wiederum jede der Strukturen enthalten kann. 

3) Jede Struktur besitzt einen einzigen Eingang und einen einzigen Ausgang. 

Einige Beispiele der in Bild 13-15 gezeigten bedingten BEISPIELE 
Struktur sind: VON 

STRUKTUREN 

1) S2 inbegriffen: 

ifX » Othen NPOS-NPOS + 1 
eise NNEG - NNEG + 1 

Sowohl S1 wie S2 sind einzelne Anweisungen. 

2) S2 weggelassen: 
ifX # Olhen Y- 1/X 

Hier wird keine Tätigkeit ausgeführt, wenn C (X # 0) falsch ist. S2 und "sonst” 
kann in diesem Fall weggelassen werden 
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Einige Beispiele der in Bild 13-16 dargestellten Schleifenstrukturen sind: 

1) Bilde die Summe der ganzen Zahlen von 1 bis N. 

1 = 0 

SUM-0 
do while l<N 

I - 1+1 

SUM -SUM 
end 

Der Computer führt die Schleife so lange aus. wie l< N. Wenn N - 0. wird das 
Programm innerhalb des "führe aus solange" überhaupt nicht ausgeführt. 

2) Zähle Zeichen in einer Anordnung SENTENCE bis Sie einen ASCII-Punkt 
finden. 

NCHAR-0 

do while SENTENCE (NCHAR) # PERIOD 
NCHAR - NCHAR+1 
end 

Der Computer fühlt die Schleife so lange aus. wie das Zeichen in SENTENCE 
kein ASCII-Punkt ist. Die Zählung ist 0, wenn das erste Zeichen ein Punkt 
ist. 


Die Vorteile der strukturierten Programmierung sind: 


1) Die Sequenz der Operationen ist leicht zu ver- ctdm* tudhxotci 

folgen. Dadurch wird das Testen und Fehler- °I" l i , iTURIERTEN 

suchen leicht gemacht PROGRAMMIERUNG 

2) Die Anzahl der Strukturen ist begrenzt und 
die Terminologie ist standardisiert. 

3) Die Strukturen sind leicht in Module umzuwandeln. 

4) Theoretische Überlegungen haben ergeben, daß der gegebene Satz von 
Strukturen vollständig ist, das heißt, alle Programme können mit diesen drei 
Strukturen geschrieben werden. 

5) Die strukturierte Version eines Programmes dokumentiert sich zum Teil 
selbst und ist verhältnismäßig leicht zu lesen. 

6) Struktunerte Programme sind leicht mit Flußdiagrammen oder anderen grafi¬ 
schen Methoden zu beschreiben. 

7) Strukturierte Programmierung hat sich in der Praxis zur Steigerung der Pro- 
duktivifä't des Programmierers bewährt 


Strukturierte Programmierung zwingt den Programmierer grundsätzlich zu 
mehr Disziplin als modulare Programmierung. Das Ergebnis ist mehr Systema¬ 
tik und besser organisierte Programme. 
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Nachteile der strukturierten Programmierung sind: 

1) Nur einige wenige höhere Programmierspra 
chen (z.B. PL/M, PASCAL) werden die Struk¬ 
turen direkt annehmen. Der Programmierer 
muß daher eine zusätzliche Übersetzungsstute verwenden, um die Strukturen 
in den Assemblersprachen-Code umzuwandeln. Die struktunerte Version des 
Programmes ist ledoch häufig als Dokumentation sehr nützlich. 

2) Strukturierte Programme werden häufig langsamer ausgeführt und benötigen 
mehr Speicher als unstrukturierte Programme. 

3) Die Begrenzung der Strukturen auf drei grundlegende Formen macht man¬ 
che Aufgaben in der Ausführung sehr mühsam. Die Vollständigkeit der Struk¬ 
turen bedeutet nur, daß alle Programme mit ihnen ausgeführt werden kön¬ 
nen. Es bedeutet nicht, daß ein gegebenes Programm effizient und bequem 
geschaffen werden kann. 

4) Die Standard-Strukturen sind häufig etwas verwirrend, d.h. verschachtelte 
Strukturen "wenn-dann-sonst" (if-then-else) können sehr schwiehg zu lesen 
sein, da es keine deutliche Anzeige geben kann, wo eine hiervon endet Eine 
Serie von ''Führe-aus-solange"-Schlelfen kann ebenfalls schwierig zu lesen 
sein. 

5) Strukturierte Programme berücksichtigen nur die Sequenz von Programm- 
Operationen, nicht den Datenfluß. Daher können die Strukturen Daten 
manchmal sehr mühsam behandeln. 

6) Wenige Programmierer sind mit der strukturierten Programmierung vertraut. 
Viele finden die Standard-Struktur mühsam und hemmend. 

Wir wollen uns nicht als Richter über die Verwendung der strukturierten Pro¬ 
grammierung auf schwingen. Es ist eben ein bestimmter Weg, Programm-Ent¬ 
wicklung systematisch durchzuführen. Im allgemeinen ist sie bei folgenden Si¬ 
tuationen am nützlichsten: 


1) Größere Programme, wahrscheinlich tausend 
oder mehr Befehle. 

2) Anwendungen, in denen die Verwendung des 
Speichers nicht kritisch ist. 

3) Anwendungen mit kleinen Stückzahlen, wo die 
Kosten für die Software-Entwicklung und die 
Fehlersuche wichtige Faktoren sind. 

4) Anwendungen, die keine komplexen Daten-Strukturen enthalten. 

5) Anwendungen mit Reihen-Manipulationen, Prozess-Steuerung oder andere 
Algorithmen, anstatt einfacher Bit-Manipulationen. 

6) Anwendungen, in denen höhere Programmiersprachen verwendet werden. 

Für die Zukunft ist anzunehmen, daß die Speicherkosten weiter sinken, die 
durchschnittliche Länge von Mikroprozessor-Programmen steigt und die Ko¬ 
sten der Software-Entwicklung abnehmen. Daher werden Methoden wie die 
strukturierte Programmierung, die die Software-Entwicklungskosten für grös¬ 
sere Programme verringert, jedoch mehr Speicher benötigt, auch wertvoller 
werden. 

Wenn die Grundlagen der strukturierten Programmierung gewöhnlich in höhe¬ 
ren Programmiersprachen Vorkommen, so bedeutet dies nicht, daß strukturierte 
Programmierung nicht in der Assembler Sprachen-Programmierung anwendbar 
ist. Im Gegenteil, der Assembler-Sprachen-Programmierer, der in dieser Pro¬ 
grammiersprache weitgehende Freiheit besitzt, benötigt strukturierte Pro¬ 
grammierung in besonders hohem Maße. Die Schaffung von Modulen mit ein¬ 
zelnen Eintritts- und Austritts-Punkten, die Verwendung von Steuer-Strukturen 
und die Möglichkeit, jedes Modul einfachst aufzubauen, macht die Codierung 
in Assemblersprache besonders effizient. 


WANN SOLLTE 
STRUKTURIERTE 
PROGRAMMIERUNG 
VERWENDET WERDEN 


NACHTEILE DER 

STRUKTURIERTEN 

PROGRAMMIERUNG 


BEISPIELE 

Reaktion auf einen Schalter 

Die strukturierte Version dieses Beispieles ist: 

SWITCH-OFF 
dowhile SWITCH-OFF 
READ SWITCH 
end 

LIGHT-ON 
DELAY 1 
LIGHT-OFF 

EIN uns AUS müssen die enfsprechnenden Definitionen für den Schalter und die 
Lampe besitzen. Wir nehmen an, daß VERZÖGERUNG ein Modul ist, das eine 
Verzögerung ergibt, die durch seine Parameter in Sekunden gegeben ist. 

Eine Anweisung in einem strukturierten Programm kann in Wirklichkeit ein Un¬ 
terprogramm sein. Um jedoch den Regeln der strukturierten Programmierung 
gerecht zu werden, darf das Unterprogramm keine anderen Ausgänge haben, 
als den einen, der die Steuerung zum Hauptprogramm zurückgibt. 

Da "Führe aus solange" die Bedingung vor Ausführung der Schleife prüft, setzen 
wir vor dem Start die Variable SCHALTER auf AUS. Die strukturierte Program¬ 
mierung ist übersichtlich, lesbar und leicht von Hand zu überprüfen. Wir werden 
ledoch wahrscheinlich etwas mehr Speicher als bei einem unstrukturierten Pro¬ 
gramm benötigen, das nicht SCHALTER initialisieren müsste und die Lese- und 
Prüf-Verfahren miteinander kombinieren könnte. 


STRUKTURIERTE 
PROGRAMMIERUNG BEI 
DEM SCHALTER- UND 
LAMPENSYSTEM 
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Der Speicher-Lader mit Schaltern 

Der Speicher-Lader mit Schaltern ist eine etwas STRUKTURIERTE 
komplexere Aufgabe für die strukturierte Pro- PROGRAMMIERUNG 
grammierung. Wir können das Flußdiagramm DES SPEICHERLADERS 
von Bild 13-9 wie folgt darstellen (ein . zeigt ei- MIT SCHALTERN 
nen Kommentar an): 

INITIALISIERE VARIABLEN 

HIADDRESS - 0 
LOADDRESS-0 

iülESES PROGRAMM VERWENDET EINEN "FÜHRE AUS SOLANGE"-AUFBAU 
.OHNE BEDINGUNG 

.(GENANNT EINFACH "FUHRE IMMER AUS") DESHALB FÜHRT DAS SYSTEM 
.KONTINUIERLICH DAS PROGRAMM AUS, DAS IN SEINER "FÜHRE AUS 
.SOLANGE’ -SCHLEIFE ENTHALTEN IST 


führe immer aus 

.TESTE AUF HIADDRESS-TASTE, FÜHRE DIE ERFORDERLICHE VERARBEI¬ 
TUNG AUS, WENN SIE EIN IST. 

if HIADDRESSBUTTON - 1 then 
begin 

HIADDRESS- SWITCHES 
LIGHTS-SWITCHES 
do 

DELAY (DEBOUNCE TIME) 
until HIADDRBUTTON ¥■ 1 
end 

.TESTE AUF LOADDRESS-TASTE, FÜHRE VERARBEITUNG DER NIEDRI¬ 
GEN .ADRESSE AUS, WENN SIE AUF EIN IST. 

if LOADDRBUTTON - 1 then 
begin 

LOADDRESS - SWITCHES 
LIGHTS-SWITCHES 
do 

DELAY (DEBOUNCE TIME) 
until LOADDRBUTTON * 1 
end 

.'TESTE AUF DATEN-TASTE, UND SPEICHERE DATEN IN DEN SPEICHER. 
.WENN SIE AUF EIN IST. 

if DATABUTTON = 1 then 
begin 

DATA-SWITCHES 
LIGHTS- SWITCHES 
(HIADDRESS, LOADDRESS) - DATA 
do 

DELAY (DEBOUNCE TIME) 
until DATABUTTON * 1 
end 

end 
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DAS OBIGE "END" BEENDET DIE ENDLOSE SCHLEIFE, 


Strukturierte Programme sind nicht leicht zu schreiben, können jedoch einen gu 
ten Einblick in die gesamte Programmlogik geben. Sie können die Logik der 
strukturierten Programme von Hand prüfen, bevor sie einen tatsächlichen Code 
schreiben 


Das Kredit-Verifikations-Terminal 


Sehen wir uns die Tastatur-Eingabe für das 
Terminal an. Wir wollen annehmen, daß die An¬ 
zeige-Anordnung ENTRY ist, der Tastatur-Abtast - 
Impuls KEYSTROBE ist und die Tastatur-Daten 
KEYIN. Das strukturierte Programm ohne die 
Funktions-Tasten ist: 

NKEYS -10 


STRUKTURIERTES 
PROGRAMM FÜR DAS 
KREDIT- 
VERIFIKATIONS¬ 
TERMINAL_ 

STRUKTURIERTE 

TASTATUR-ROUTINE 


^LÖSCHE ENTRY FÜR DEN START 


do while NKEYS > 0 
NKEYS-NKEYS 1 
ENTRY(NKEYS)-0 
end 


.HOLE EIN VOLLSTÄNDIGES EINGABE VON DER TASTATUR 


do while NKEYS < 10 
if KEYSTROBE -ACTIV then 
begin 

KEYSTROBE = INACTIV 
ENTRY (NKEYS)-KEYIN 
NKEYS-NKEYS+1 

end 

end 

Das Hinzufügen der SENDE-Taste bedeutet, daß das Programm zusätzliche 
Ziffern ignorieren muß, nachdem es eine vollständige Eingabe hat und die 
SENDE-Taste ignorieren muß, bis es eine vollständige Eingabe besitzt. Das 
strukturierte Programm lautet: 

NKEYS-1 0 

.LÖSCHE EINGABE ZUM START 

do while NKEYS > 0 
NKEYS - NKEYS -1 
ENTRY(NKEYS)= 0 
end 
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! WARTE AUF VOLLSTÄNDIGE EINGABE UND SENDE-TASTE 

dowhile KEY it SEND OR NKEYS 4 10 
il KEYSTROBE = AKTIV then 
begin 

KEYSTROBE = INACTIV 

KEY -KEYIN 

if NKEYS * 10 AND KEY * SEND then 
begin 

ENTRY(NKEYS)= KEY 
NKEYS = NKEYSf1 
end 

end 

end 

Beachten Sie folgende Eigenschaflen dieses struklurierten Programmes-. 

1) Das zweite "wenn-dann" isl im erslen verschachtelt, da die Tasten nur einge¬ 
geben werden, nachdem der Abtasl-Impuls erkannt wurde. Wenn sich das 
zweite "wenn-dann" auf der gleichen Ebene wie das erste befinden würde, 
könnte eine einzelne Taste die Eingabe füllen, da sein Wert in der Anord¬ 
nung während jeder Wiederholung der "führe aus-solange" Schleife einge¬ 
geben werden könnte. 

2) KEY muß anfangs nicht definiert werden, da KEY auf null gesetzt wird, als Teil 
des Löschens der Eingabe. 

Das Hinzufügen der CLEAR-Taste gestattet dem Programm das Löschen der 
Eingabe durch Simulieren eines Drückens von CLEAR, d h durch Setzen von 
NKEYS auf 1 0 und KEY auf CLEAR vor dem Start Das strukturierte Programm 
muß auch nur Stellen löschen, die vorher gefüllt wurden Das neue strukturierte 
Programm lautet: 

IsiMULIERE VOLLSTÄNDIGES LÖSCHEN 


NKEYS - 10 
KEY-LOSCHEN 

! WARTE AUF VOLLSTÄNDIGE EINGABE UND SENDE-TASTE 
do while KEY * SEND OR NKEYS + 10 

löSCHE GESAMTE EINGABE, WENN CLEAR-TASTE BETÄTIGT WIRD 
it KEY-CLEAR then 
begin 
KEY-0 

dowhile NKEYS > 0 
NKEYS-NKEYS-1 
ENTRY(NKEYS)=0 
end 
end 
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.HOLE ZIFFER WENN EINGABE UNVOLLSTÄNDIG 


if KEYSTROBE- INAKTIV then 
begin 

KEYSTROBE-INACTIV 

KEYSTROBE KEYIN 

il KEY < 10 AND NKEYS * 10 then 

begin 

ENTRY (NKEYS)-KEY 
NKEYS-NKEYS-t-1 
end 
end 
end 

Beachten Sie, daß das Programm KEY auf null nach dem Löschen der Anord¬ 
nung stellt, so daß die Operation nicht wiederholt wird. 


Wir können auf ähnliche Weise ein strukturier¬ 
tes Programm für die Empfangs-Routine aufstel¬ 
len, Ein anfängliches Programm könnte nur nach 
dem Nachrichten-Kopf und den Abschlußzeichen 
Ausschau halten. 


STRUKTURIERTE 

EMPFANGS¬ 

ROUTINE 


Wir wollen annehmen, daß das RSTB ein Indikator ist. der sagt, daß ein Zeichen 
bereit ist. Das strukturierte Programm lautet: 


.LÖSCHE NACHRICHTENKOPF-FLAG ZUM START 
HFLAG =0 

.WARTE AUF NACHRICHTENKOPF UND ABSCHLUSSZEICHEN 
do while HFLAG - 0 OR CHAR * TRAILER 

.HOLE ZEICHEN WENN BEREIT. HALTE AUSSCHAU NACH NACHRICHTEN- 
.KOPF 

if RSTB - ACTIV then 
begin 

RSTB-INACTIV 
CHAR-INPUT 

if CHAR - HEADER then HFLAG - 1 
end 

Nun können wir den Abschnitt hinzufügen, der die Adresse der Nachrichten 
gegenüber den drei Ziffern im TERMINAL ADDRESS (TERMADDR) prüft. 
Wenn eine der entsprechenden Ziffern nicht gleich ist, dann wird das 
ADDRESS MATCH-Ffag (ADDRMATCH) auf 1 gesetzt. 
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• LÖSCHE HEADER-FLAG, ADDRESS-MATCH-FLAG. ADRESSENZÄHLER FÜR 
•DEN START 

HFLAG - 0 
ADDRMATCH =0 
ADDRCTR- 0 

•WARTE AUF NACHRICHTENKOPF, BESTIMMUNGSADRESSE UND 
.ABSCHLUSSZEICHEN 

do whtle HFLAG - 0 OR CHAR * TRAILER OR ADDRCTR * 3 

.*HOLE ZEICHEN WENN BEREIT 

ifRSTB- ACTIV then 
begin 

RSTB- INACTIV 
CHAR- INPUT 
end 

iPRÜFE AUF TERMINAL-ADRESSE UND HEADER 

il HF LAG - 1 AND ADDRCTR # 3 then 
begin 

ADDRMATCH 1 
ADDRCTR-ADDRCTR t-1 
il CHAR- HEADER then HFLAG- 1 
end 

Das Programm muß nun auf einen Nachrichtenkopf warten, einen dreistelli¬ 
gen Identifikationscode und auf ein Abscchlußzeichen. Sie müssen sehr sorgfäl¬ 
tig beachten, was während der Wiederholung geschieht, wenn das Programm 
den Nachrichtenkopf lindet und was geschieht, wenn ein fehlerhaftes Identifika- 
tions-Codezeichen gleich dem Abschlußzeichen ist. 

Zusätzlich kann die Nachricht in MESSG gespeichert werden. NMESS ist die 
Zahl der Zeichen in der Nachricht. Wenn sie am Ende nicht null ist, weiß das 
Programm, daß das Terminal eine gültige Nachricht empfangen hat. Wir haben 
nicht versucht, die Logik-Ausdrücke in diesem Programm auf ein Minimum zu 
reduzieren. 

.'LÖSCHE FLAGS. ZAHLER ZUM START 

HFLAG = 0 
ADDRMATCH-0 
ADDRCTR=0 
NMESS = 0 

.WARTE AUF HEADER, BESTIMMUNGSADRESSE UND ABSCHLUSSZEICHEN 
do while HFLAG - 0 OR CHAR * TRAILER or ADDRCTR * 3 
.HOLE ZEICHEN WENN BEREIT 

il RSTB-ACTIV then 
begin 

RSTB= INAKTIV 
CHAR-INPUT 
end 


.LIES NACHRICHT WENN BESTIMMUNGSADRESSE TERMINAL-ADRESSE 

if HFLAG-1 AND ADDRCTR 3 then 
if ADDRMATCH 0 and CHAR * TRAILER then 
begin 

MESSG (NMESS) = CHAR 
NMESS »NMESS+1 
end 

.PRÜFE AUF TERMINAL-ADRESSE 

if HFLAG 1 AND ADDRCTR-3 then 
il CHAR TERMADDR(ADDRCTR) then 
begin 

ADDRMATCH 1 
ADDRCTR ADDCRT+1 

end 

.HALTE NACH NACHRICHTENKOPF AUSSCHAU 

if CHAR - HEADER then HFLAG = 1 
end 

Das Programm prüft nur auf den Identifikations-Code, wenn es einen Nachrich¬ 
tenkopf während einer vorhergehenden Wiederholung gefunden hat. Es nimmt 
die Nachrichten nur an, wenn es vorher einen Nachrichtenkopf und eine voll¬ 
ständige, übereinstimmende Bestimmungs-Adresse gefunden hat. Das Pro¬ 
gramm muß während der Wiederholungen ordnungsgemäß arbeiten, wenn es 
den Nachrichtenkopf, das Abschlußzeichen und die letzte Stelle der Bestim¬ 
mungs-Adresse findet. Es darf nicht versuchen, den Nachrichtenkopf mit der 
Bestimmungs-Adresse in Übereinstimmung zu bringen oder das Abschlußzei¬ 
chen oder die letzte Stelle der Bestimmungs-Adresse in die Nach¬ 
richt zu plazieren. Sie könnten versuchen, den Rest der Logik vom Flußdia- 
gramm (Bild 13-13) dem str vom Flußdiagramm (Bild 13-13) dem strukturier¬ 
ten Programm hinzuzufügen. Beachten Sie, daß die Reihenfolge der Operatio¬ 
nen häufig kritisch ist. Sie müssen sichergehen, daß das Programm nicht eine 
Phase abschließt und die nächste während derselben Wiederholung beginnt. 


ÜBERBLICK ÜBER DIE STRUKTURIERTE PROGRAMMIERUNG 

Strukturierte Programmierung bringt zwangsläufig eine entsprechende Ord¬ 
nung in die Programm-Entwicklung. Sie sind gezwungen, die Arten der von 
Ihnen verwendeten Strukturen zu begrenzen, sowie die Sequenz der Operatio¬ 
nen. Sie liefert Strukturen mit Einzel-Eingang und Einzel-Ausgang, die Sie auf 
logische Genauigkeit prüfen können. Strukturierte Programmierung macht den 
Entwickler häufig auf Ungenauigkeiten oder mögliche Kombinationen von Ein¬ 
gaben aufmerksam. Strukturierte Programmierung ist kein Allheilmittel, bringt 
jedoch einige Ordnung in einen anderweitig verwirrenden Vorgang. Die struk¬ 
turierte Programmierung sollte auch bei der Fehlersuche, beim Testen und 
Dokumentieren helfen. 

Strukturierte Programmierung ist nicht einfach. Der Programmierer muß nicht 
nur die Aufgabe entsprechend definieren, er muß auch die Logik sorgfältig 
durcharbeiten. Dies ist mühsam und schwierig, kann jedoch ein klar geschrie¬ 
benes und funktionierendes Programm ergeben. 
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Die speziellen Strukturen, die wir vorgestellt haben, sind 
nicht ideal, und sind häufig mühsam in der Anwendung. 

Zusätzlich kann es schwierig sein zu unterscheiden, wo 
eine eine Struktur endet und eine andere beginnt, speziell 
wenn sie verschachtelt sind. Theoretiker könnten bessere Strukturen in der 
Zukunft liefern, oder Entwickler könnten eigene hinzufügen. Irgend eine Art 
eines Abschlußzeichens für ]ede Struktur erscheint erforderlich, da ein Verzah¬ 
nen nicht immer die Situation deutlicher macht. "End' ist ein logisches Ab¬ 
schlußzeichen für eine "Führe aus-solange"-Schleite. Dies ist ein deutliches Ab¬ 
schlußzeichen, tedoch lür die "wenn dann-sonst" (it-then e!se)-Anweisung ha¬ 
ben einige Theoretiker 'endif" oder "fi" ("if" umgedreht} vorgeschlagen, aber 
diese beiden sind unhandlich und tragen nicht zur Lesbarkeit der Programme bei. 


BEGRENZER 

FÜR 

STRUKTUREN 


Diese Verfahren ist das sogenannte Top- 
Down-Verfahren, das man im Deutschen am 
besten mit "schrittweiser Verfeinerung" bezeich¬ 
nen könnte. Hier beginnen wir mit dem 
Schreiben eines Gesamt-Überwachungs-Pro- 
grammes. Wir ersetzen die Undefinierten Un¬ 
terprogramme durch Programm-'Stümpfe" 
(stubs), Zwischenprogramme, die entweder die 
Eingabe aufzeichnen, die Antwort auf ein 
gewähltes Testprogramm liefern oder auch 
nichts ausführen. Wir testen dann das Über¬ 
wachungsprogramm um festzustellen, ob sei¬ 
ne Logik korrekt ist. 


TOP-DOWN- 

ENTWICKLUNGS- 

METHODEN 


PROGRAMM¬ 

STÜMPFE 


ERWEITERUNG 
VON PROGRAMM¬ 
STÜMPFEN 


VORTEILE DER 

TOP-DOWN- 

ENTWICKLUNG 


Wir schlagen folgende Regeln für die Anwen 
düng strukturierter Programmierung vor: 


1) Beginnen Sie mit dem Schreiben eines grundlegenden Flußdiagrammes, um 

die Logik in dem Programm zu definieren. 

2) Beginnen Sie mit den Kostruktionen "wenn-dann-sonst" und "führe aus- 
solange". Sie sind als kompletter Satz bekannt, das heißt, jedes Programm 
kann mit den Ausdrücken dieser Strukturen geschrieben werden. 

3) Bringen Sie jede Ebene in einen gewissen Abstand von der vorhergehenden 
Ebene an, so daß Sie wissen, zu welcher entsprechenden Anweisung sie ge¬ 
hören 

4) Verwenden Sie Abschlußzeichen für jede Struktur, z.B. "end" für die "führe 
aus-solange" und "endif" oder "fi" für die "wenn-dann-sonst". Die Abschluß¬ 
zeichen sowie die Trennung sollte die Programme angemessen klar machen 

5) Achten Sie auf Einfachheit und Lesbarkeit. Lassen Sie genügend Zwischen¬ 
räume, verwenden Sie bedeutungsvolle Namen und machen Sie Ausdrücke 
so klar wie möglich. Versuchen Sie nicht die Logik auf Kosten der Klarheit zu 
minimisieren. 

6) Kommentieren Sie das Programm ausführlich 

7) Prüfen Sie die Logik. Versuchen Sie alle extremen Falle oder speziellen Be¬ 
dingungen und einige Beispiele. Einen logischen Fehler, den Sie jetzt auffin¬ 
den, wird Ihnen später viel Arger ersparen 


REGELN FÜR 

STRUKTURIERTE 

PROGRAMMIERUNG 


Wir setzen mit der Erweiterung der Stümpfe fort. Jeder Stumpf wird häufig 
Unter-Aufgaben enthalten, die wir zeitweilig als Stümpfe darstellen werden. 
Dieser Vorgang der Erweiterung, Fehlersuche und Testen wird fortgesetzt, 
bis alle Stümpfe durch ein funktionierendes Programm ersetzt werden. 

Beachten Sie, daß Testen und Zusammensetzung in jeder Ebenen auftreten, 
statt alle am Ende Es sind keine speziellen Treiber oder Datenerzeugungs- 
Programme erforderlich Wir bekommen eine Vorstellung, wo wir uns genau 
innerhalb der Entwicklung befinden Das Verfahren der schrittweisen Verfei¬ 
nerung nimmt die modulare Programmierung an und ist ebenfalls mit struk¬ 
turierter Programmierung kompatibel. 


Die Nachteile der schrittweisen Verfeinerung sind: 


1) Die gesamte Entwicklung kann die System- 
Hardware wenig berücksichtigen. 

2) Sie benützt nicht besonders gut die Vorteile 
der existierenden Software 

3) Ein geeigneter Stumpf kann schwierig zu schreiben sein, speziell wenn der 
gleiche Stumpf ordnungsgemäß an mehreren verschiedenen Stellen arbeiten 
muß. 

4) Das Verfahren der schrittweisen Verfeinerung ergibt keine allgemein nütz¬ 
lichen Module. 

5) Fehler in der obersten Ebene haben katastrophale Auswirkung, während 
Fehler bei der Bottom-up-Entwicklung gewöhnlich auf spezielle Module be¬ 
schränkt sind. 


NACHTEILE DER 
SCHRITTWEISEN 
VERFEINERUNG 


"TOP-DOWN"-ENT WICKLUNG 
(SCHRITTWEISE VERFEINERUNG) 


Das verbleibende Problem besteht darin, die 
Module oder Strukturen zu prüfen und zusam¬ 
menzusetzen. Sicher wollen wir, daß eine große 
Aufgabe in Unter-Aufgaben aufgeteilt wird. 

Aber wie prüfen wir die Unter-Aufgaben isoliert und bringen sie dann zu¬ 
sammen? Das Standard-Verfahren, genannt "Bottom-up”-Entwicklung, be¬ 
nötigt zusätzliche Arbeit für das Testen und Fehlersuchen und läßt die ge¬ 
samte Integrations-Auf gäbe bis zum Schluß. Was wir benötigen, ist ein Ver¬ 
fahren, das uns das Testen und Fehlersuchen in der tatsächlichen Pro¬ 
gramm-Umgebung ermöglicht und die System-Integration in eine Reihe von 
modularen Aufgaben unterteilt. 


In großen Programmier-Vorhaben hat sich das Verfahren der schrittweisen 
Verfeinerung als große Verbesserung für die Produktivität des Programmierers 
erwiesen. Jedoch die meisten dieser Projekte haben auch die Bottom-up- 
Entwicklung in Fällen verwendet, in denen das Verfahren der schrittweisen 
Verfeinerung eine Menge zusätzlicher Arbeit ergeben hätte. 

Die schrittweise Verfeinerung ist ein nützliches Hilfsmittel, das jedoch nicht 
bis ins Extrem verwendet werden sollte. Sie besitzt die gleichen Regeln für 
das Testen von Systemen und der Integration, wie die strukturierte Program¬ 
mierung für die Modul-Entwicklung. Das Verfahren ist jedoch allgemeiner ver¬ 
wendbar, da es nicht wirklich die Verwendung programmierter Logik annimmt. 
Die schrittweise Verfeinerung ergibt nicht immer die effizienteste Ausführung. 


BOTTOM-UP- 

ENTWICKLUNG 
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BEISPIELE 

Reaktion aut einen Schalter 


Das erste Beispiel für die strukturierte Program¬ 
mierung demonstriert die schrittweise Verfeine¬ 
rung. Das Programm war: 

SWITCH» OFF 
do while SWITCH - OFF 
READ SWITCH 

end 

LIGHT =ON 
DELAY 1 
LIGHT OFF 

Die meisten dieser Anwendungen sind wirklich Stümpfe, da keine von ihnen 
voll definiert isL Was bedeutet zum Beispiel LIES SCHALTER? Wenn der Schal¬ 
ter ein Bit des Eingangs-Ports SPORT ist, bedeutetes in Wirklichkeit 

SCHALTER = SPORT UND SMASK 

wobei SMASK ein " 1 "-Bit in der entsprechenden Position besitzt 

Ähnliches bedeutet VERZÖGERUNG 1 tatsächlich (wenn der Prozessor selbst 
die Verzögerung liefert): 

REG »COUNT 
do while REG / 0 
REG »REG 1 

end 

COUNT (ZÄHLUNG) ist die entsprechende Zahl zur Lielerung einer Verzöger¬ 
ung von einer Sekunde. Die erweiterte Version des Programmes ist: 

SWITCH =0 
do while SWITCH-0 
SWITCH - SPORT AND MASK 
end 

LIGHT - ON 
REG -COUNT 
do while REG ^ 0 
REG» REG -1 
end 

LIGHT» NOT (LIGHT) 

Sicher ist diese Programm expliziter und könnte leichter in tatsächliche Befeh¬ 
le oder Anweisungen übersetzt werden. 


SCHRITTWEISE 
VERFEINERUNG DES 
SCHALTER-UND 
LAMPENSYSTEMS 


Der Speicher-Lader mit Schaltern 


Dieses Beipiet ist komplexer als das erste Bei¬ 
spiel, so daß wir systematisch Vorgehen müssen. 

Hier enthält das strukturierte Programm wieder 
tatsächlich Stümpfe. 

Zum Beispiel, wenn die HIGH ADDRESS-Taste 
ein Bit des Eingangs-Ports CPORT ist, so bedeu¬ 
tet "wenn HIADDRBUTTON - 1" wirklich: 

1) Gib von CPORT ein 

2) Komplementiere. 

3) Logisch UNDiere mitHAMASK. 

wobei HAMASK eine "1" in der entsprechenden Bit-Position besitzt und andern¬ 
falls Nullen, Ähnlich bedeutet die Bedingung "wenn DATABUTTOM - 1" in Wirk¬ 
lichkeit: 

1) Gib von CPORT ein. 

2) Komplementiere. 

3) UNDiere logisch mit DAMASK. 

Daher könnten die anfänglichen Stümpfe den Tasten Werte zuweisen, zum Bei¬ 
spiel: 


ENTWICKLUNG MIT 
SCHRITTWEISER 
VERFEINERUNG DES 
SPEICHER-LADERS 
MIT SCHALTERN 


HIADDRBUTTON - 0 
LOADDRBUTTON- 0 
DATABUTTON -0 

Ein Ablauf des Überwachungsprogrammes sollte zeigen daß es den hienn ent¬ 
haltenen "dann (else)"-Weg durch die ’if-then-else' -Strukturen nimmt und die 
Schalter niemals liest. Ähnlich, wenn der Stumpf 

HIADDRBUTTON-1 

wäre, sollte das Überwachungsprogramm in der Schleife "do while HIADDR¬ 
BUTTON = 1'warten, bis die Taste losgelassen wird Dieser einfache 
Durchlauf prüft die gesamte Logik. 

Nun können wir mit der Erweiterung jedes Stumpfes beginnen und sehen, ob 
die Erweiterung ein vernünftiges Gesamtresultat ergibt. Beachten Sie, wie 
Fehlersuche und Testen in einer einfachen und modularen Weise fortschreitet. 

Wir erweitern den Stumpl HIADDRBUTTON- 1 auf 

LIES CPORT 

HIADDRBUTTON - NICHT (CPORT) UND HAMASK 

Dieses Programm sollte warten, bis die Taste HIGH ADDRESS geschlossen ist. 
Das Programm sollte dann die Werte der Schalter auf den Lampen anzeigen. 
Dieser Durchlauf prüft die richtige Reaktion auf die HIGH ADDRESS Taste. 

Wir erweitern dann das Tastenmodul LOW ADDRESS auf 

LIES CPORT 

HIADDRBUTTON- NICHT (CPORT) UND LAMASK 
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Mit der LOW ADDRESS-Taste in geschlossener Lage sollte das Programm die 
Werte der Schalter aut den Lampen anzeigen. Dieser Durchlautprüft die richtige 
Reaktion auf die LOW ADDRESS-Taste. 

Ähnlich können wir das Modul DATA-Taste erweitern und die richtige Reaktion 
auf diese Taste prüfen. Das gesamte Programm wurde dann auf systematische 
Weise geprüft. 

Wenn alle Stümpfe erweitert wurden, so sind die Codier-, Fehlersuch- und 
Teststufen abgeschlossen. Natürlich müssen wir genau wissen, welche Ergeb¬ 
nisse jeder Stumpf erzeugen sollte. Zahlreiche logische Fehler werden jedoch 
bei jeder Ebene erkennbar werden, ohne irgend eine weitere Erweiterung. 
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Das Verifikations-Terminal 


Dieses Beispiel besitzt natürlich mehrere Detail- 
Ebenen. Wir könnten mit dem folgenden Pro¬ 
gramm beginnen (siehe Bild 13-17 für ein Fluß¬ 
diagramm): 


KEYBOARD 

ACK-0 

do while ACK = 0 
TRANSMIT 
RECEIVE 
end 

DISPLAY 


SCHRITTWEISE 
VERFEINERUNG DES 
VERIFIKATIONS¬ 
TERMINALS 


Hier sind TASTATUR, SENDE, EMPFANGE und ANZEIGE Programmstümpfe, 
die später erweitert werden. TASTATUR zum Beispiel könnte einlach eine über¬ 
prüfte zehnstellige Zahl in das entsprechende Pufier plazieren. 
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Bild 1 3-20 Flußdiagramm für die erweiterte TASTATUR-Routine 


Wir würden mit einer ähnlichen Erweiterung, Fehlersuche und Testen von SEN¬ 
DEN, EMPFANG und ANZEIGE fortsetzen. Beachten Sie, daß Sie jedes Pro¬ 
gramm um eine Ebene erweitern sollten, so daß Sie nicht die Zusammenset¬ 
zung des ganzen Programms auf einmal ausführen. Sie müssen selbst über die 
Definition der Ebene entscheiden. Zu kleine Schritte verschwenden Zeit, wäh¬ 
rend ein zu großer Schritt Sie zu den Problemen der System-Integration zu¬ 
rückwirft, die die Entwicklung mit der schrittweisen Verfeinerung losen sollte. 


Der nächste Schritt für die Erweiterung könnte in der Bil¬ 
dung des folgenden Programmes für TASTATUR (siehe 
Bild 13-18) sein: 


VER- 0 

do while VER - 0 
COMPLETE- 0 
do while COMPLETE “0 
KEYIN 
KEYDS 
end 

VERIFY 
end 

Hier bedeutet VER- 0, daß eine Eingabe nicht venfiziert wurde VERVOLLSTÄN¬ 
DIGE (COMPLETE) - 0 bedeutet, daß diese Eingabe unvollständig ist KEYIN 
und KEYDS sind die Tastatur-Eingabe- und Anzeige-Routinen. VERIFY prüft die 
Eingabe Ein möglicher Stumpf lür KEYIN würde einfach eine zufällige Eingabe 
(v*n einer Zufallszahlen-Tabelle- oder Generator) in den Putter plazieren und 
COMPLETE aut 1 setzen. 


ERWEITERUNG 

DER 

TASTATUR¬ 

ROUTINE 
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ÜBERBLICK ÜBER DAS VERFAHREN 
DER SCHRITTWEISEN VERFEINERUNG 

Das Verfahren der schrittweisen Verfeinerung bringt Ordnung in die Test- und 
Integrations-Phasen der Programm-Entwicklung. Sie liefert ein systematisches 
Verfahren zur Erweiterung eines Flußdiagrammes oder der Aufgaben-Defini- 
tion auf eine Ebene, die zum tatsächlichen Schreiben eines Programmes erfor¬ 
derlich ist. Zusammen mit strukturierter Programmierung bilden sie ein voll¬ 
ständiges Entwicklungs-Verfahren. 

Wie die strukturierte Programmierung, ist auch das Verfahren mit der schritt¬ 
weisen Verfeinerung nicht einfach. Der Entwickler muß die Aufgabe sorgfältig 
definiert haben und sich systematisch durch die Ebenen arbeiten. Hier er¬ 
scheint die Methode wieder mühsam, aber der Vorteil kann erheblich sein, 
wenn der Entwickler tatsächlich diesen Regeln folgt. 

Wir empfehlen die folgende Lösung für das Verfahren der FORMAT DER 
schrittweisen Verfeinerung: TOP-DOWN- 

ENTWICKLUNG 

1) Beginnen Sie mit einem grundlegenden Flußdiagramm. 

2) Machen Sie die Stümpfe so vollständig und so getrennt wie möglich. 

3) Definieren Sie genau alle Ergebnisse jedes Stumpfes und wählen Sie die 
entsprechenden Test-Veilahren 

4) Prüfen Sie jede Ebene sorgfältig und systematisch. 

5) Verwenden Sie die Strukturen der strukturierten Programmierung. 

6) Erweitern Sie jeden Stumpf um eine Ebene. Versuchen Sie nicht zu viel in ei¬ 
nem Schritt auszuführen 

7) Achten Sie sorgfältig auf gemeinsame Aufgaben und Datenstrukturen. 

8) Testen Sie und suchen Sie die Fehler nach jeder Struktur-Erweiterung. Ver 
suchen Sie nicht eine ganze Ebene auf einmal auszuführen. 

9) Achten Sie darauf, was die Hardware ausführen kann. Scheuen Sie sich 
nicht zu stoppen und auch eine kleine ’'Bottom-up"-Entwicklung auszufüh¬ 
ren, wenn diese erforderlich ist. 
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ÜBERBLICK ÜBER DIE AUFGABEN-DEFINITION 
UND PROGRAMM-ENTWICKLUNG 

Sie sollten beachten, daß wir ein ganzes Kapitel aufwendeten, ohne irgend¬ 
einen speziellen Mikroprozessor oder Assemblersprache erwähnt zu haben, 
und ohne das Schreiben einer einzigen Zeile eines tatsächlichen Codes. 
Hoffentlich wissen Sie nun mehr über die Beispiele, als wenn wir von Ihnen 
am Anfang verlangt hätten, Programme zu schreiben. Obwohl wir häufig 
glauben, daß das Schreiben von Computerbefehlen der wesentliche Teil der 
Software-Entwicklung ist, ist es nur eine der leichtesten Stufen. 

Sobald Sie einige Programme geschrieben haben, wird die Stufe des Codie- 
rens sehr einfach werden. Sie werden bald den Befehlssatz lernen, erken¬ 
nen welche Befehle wirklich nützlich sind und werden dann finden, daß an¬ 
dere Stufen der Software-Entwicklung schwierig bleiben und weniger klare 
Regeln besitzen. 

Wir haben hier einige Wege vorgeschlagen, um diese wichtigen frühen 
Stufen in ein System zu bringen. In der Stufe der Aufgaben-Oefinition muß¬ 
ten Sie alle Eigenschaften des Systems definieren, seine Eingangs- und 
Ausgangs-Signale, Verarbeitung, Zeit- und Speicher-Beschränkungen und 
die Handhabung von Fehlern. Sie mußten besonders überlegen, wie das Sy¬ 
stem mit größeren Systemen zusammenarbeitet, von dem es ein Teil ist und 
ob das größere System elektrische Geräte, mechanische Geräte oder einen 
Menschen als Bedienenden umfaßt. Sie müssen in dieser Stufe mit den 
Überlegungen beginnen, wie Sie das System leicht zu bedienen und zu war¬ 
ten machen. 

In der Stufe der Programm-Entwicklung können Ihnen verschiedene Techni¬ 
ken helfen, systematisch die Logik Ihres Programmes zu spezifizieren und 
zu dokumentieren. Modulare Programmierung zwingt Sie zur Aufteilung des 
gesamten Programmes in kleine abgegrenzte Module. Strukturierte Pro¬ 
grammierung ermöglicht einen systematischen Weg zur Definition der Lo¬ 
gik derartiger Module, während die Entwicklung mit schrittweiser Verfeiner¬ 
ung ein systematisches Verfahren zur Zusammensetzung und Testen dieser 
ist. Natürlich kann Sie niemand zwingen, alle diese Verfahren zu verwen¬ 
den. Sie sind in der Tat mehr als Richtlinien gedacht. Aber sie ermöglichen 
eine einheitliche Lösung für die Definitions- und Entwicklungs-Stufen und 
Sie sollten Sie als eine Basis für die Entwicklung Ihrer eigenen Lösung be¬ 
trachten. 
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Kapitel 14 

FEHLERSUCHE UND TESTEN 


Wie wir am Beginn des vorhergehenden Kapitels testgestellt haben, gehören 
Fehlersuche und Testen zu den zeitraubendsten Stuten der Software-Entwick¬ 
lung Obwohl Verfahren wie modulare Programmierung, strukturierte Program¬ 
mierung und Entwicklung mit schrittweiser Verfeinerung die Programme ver¬ 
einfachen und die Häufigkeit von Fehlern verringern können, sind Fehlersuche 
und Testen noch immer schwierig, da sie so schlecht zu definieren sind. Die 
Auswahl einer ausreichenden Anzahl von Testdaten ist ebenfalls selten ein kla¬ 
rer oder wissenschaftlicher Vorgang Das Finden von Fehlern erscheint häufig 
als reines Glücksspiel. Es gibt wenige Aufgaben, die manchmal so frustrierend 
sein können, wie das Suchen von Fehlern in Programmen. 

Dieses Kapitel wird zuerst die verfügbaren Hilfsmittel bei der Fehlersuche be¬ 
schreiben. Es werden dann grundlegende Fehlersuch-Verfahren besprochen, 
die häufigsten Arten von Fehlem beschrieben und einige Beispiele für Fehler¬ 
suche in Programmen vorgestellt. Im letzten Abschnitt wird beschrieben, wie 
Testdaten und Testprogramme auszuwählen sind. 

Wir können nicht mehr tun, als den Zweck der meisten Fehlersuch-Hilfsmittel zu 
beschreiben. In diesem Bereich gibt es kaum eine Standardisierung und es ist 
nicht möglich, alle momentan verfügbaren Bausteine und Programme zu be¬ 
sprechen. Die Beispiele sollten Ihnen eine Vorstellung von der Anwendung, den 
Vorteilen und den Grenzen spezieller Hardware oder Software Hilfsmittel ge¬ 
ben. 


EINFACHE FEHLERSUCH-HILFSMITTEL 


Die einfachsten Hilfsmittet für das Aufsuchen von Fehlern sind: 


• Eine Einzelschritt-Einrichtung 

• Eine Haltepunkt-Einrichtung 

• Ein Programm für einen Register-Auszug 

• Ein Programm für einen Speicher Auszug 


EINZEL¬ 

SCHRITT 


Die Einzelschritt-Einrichtung gestattet Ihnen, das Pro¬ 
gramm schrittweise, zu durchlaufen. 

Die meisten aul dem 6502 basierende Mikrocomputer besitzen diese Möglich¬ 
keit, da die Schaltung verhältnismäßig einfach ist. Natürlich sind die einzigen 
sichtbaren Dinge, wenn der Computer einen Einzelschritt ausführt, die Zustän¬ 
de der von Ihnen überwachten Ausgangsleitungen. Die wichtigsten Leitungen 

sind: 


• Datenbus 

• Adressenbus 

• Steuerleitungen 

• SYNC (Synchronisation) und READ/WRITE 
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Wenn Sie diese Leitungen (entweder in Hardware oder in Software) überwa¬ 
chen, so werden Sie die jeweiligen Adressen, Befehle und Daten bei Ausfüh¬ 
rung des Programmes sehen können. Sie werden imstande sein zu sagen, wei¬ 
che Art von Operationen die CPU ausführt. Diese Informationen werden Sie 
über Fehler, wie falsche Sprungbefehle, ausgelassene oder falsche Adressen, 
fehlerhaüe Operationscodes oder falsche Datenwerte unterrichten. Sie können 
jedoch nicht den Inhalt der Register und Flags erkennen, ohne einige zusätzli¬ 
che Fehlersuch-Möglichkeiten oder ohne einer speziellen Sequenz von Befeh¬ 
len. Zahlreiche Operationen des Programmes können nicht unmittelbar geprüft 
werden. 

Es gibt zahlreiche Fehler, die Sie mit dem Ein- GRENZEN DES 

zelschntt-Verlahren nicht auffinden können. Dies EINZELSCHRITT- 

sind Fehler in der zeitlichen Steuerung und Feh- VERFAHRENS _ 

ler in den ünterbrechungs- oder DMA-Systemen 

Ferner ist das Einzelschritt-Verfahren sehr langsam, wobei ein Programm mit 
einer Geschwindigkeit ausgeführt wird, die etwa ein Millionstel der Geschwin¬ 
digkeit des Prozessors beträgt. Wenn Sie daher nur eine Sekunde der echten 
Prozessorzeit in Einzelschntten durchlaufen, würde dies mehr als zehn Tage 
dauern Das Einzelschritt-Verfahren ist nur dann nützlich, wenn kurze Be¬ 
fehls-Sequenzen zu überprüfen sind. __ 

Ein Haltepunkt (breakpoint) ist eine Stelle, bei der das | HALTEPUNKT | 
Programm automatisch halten oder warten wird, so daß 
der Anwender den momentanen Status des Systems prüfen kann. Das 
Programm wird gewöhnlich nicht neuerlich starten, bis der Operator dies 
wünscht. Der Haltepunkt gestattet ihnen, einen ganzen Abschnitt eines Pro¬ 
grammes zu uberprüfen. Wenn Sie daher feststellen wollen, ob eine Imtiali- 
sierungs-Routine korrekt ist, können Sie einen Haltepunkt am Ende dieser 
plazieren und das Programm ablaufen lassen. Sie können dann Speicherplät¬ 
ze und Register prüfen um festzustellen, ob der gesamte Abschnitt nchtig ar¬ 
beitet Beachten Sie jedoch, daß falls der Abschnitt nicht in Ordnung ist. Sie 
trotzdem den Fehler noch aufsuchen müssen, entweder mit früheren FHal- 
tepunkten oder mit dem Einzelschritt-Verfahren. 

Haltepunkte ergänzen das Einzelschritt-Verfahren. Sie können Haltepunkte 
verwenden, entweder um den Fehler zu lokalisieren oder die Abschnitte zu 
durchlaufen von denen Sie wissen, daß sie korrekt sind. Dann können Sie die 
detaillierte Fehlersuche mit dem Einzelschritt-Verfahren ausführen. Beachten 
Sie, daß Flaltepunkte die zeitliche Steuerung des Programmes nicht beeinflus¬ 
sen, sie können daher zum Prüfen von Eingabe/Ausgabe und Unterbrechungen 
eingesetzt werden. 


14-2 


Haltepunkte verwenden häufig einen Teil oder das gesamte 
Mikroprozessor-Unterbrechungssystem. 

Einige Mikroprozessoren besitzen eine spezielle Software-Unterbrechung oder 
"Fallen" (Traps), die als Haltepunkte verwendet werden können Der Befehl BRK 
(Force Break) des 6502 kann als Haltepunkt dienen. Wenn Sie nicht bereits die 
maskierbare Unterbrechung (IRQ) und die nicht-maskierbare Unterbrechung 
(IMMI) in Ihrem Programm verwenden, so lassen sich diese Vektoren als extern 
gesteuerte Haltepunkte einsetzen Tabelle 14-1 zeigt die Adressen der ver¬ 
schiedenen Unterbrechungs-Vektoren des 6502. Kapitel 1 2 beschreibt die Vek¬ 
toren detaillierter. Die Haftepunkt Routine kann den Inhalt von Registern und 
Speichern ausdrucken oder einfach warten (durch Ausführung eines bedingten 
Sprunges, abhängig von einer Schalter-Eingabe), bis der Anwender dem Com¬ 
puter gestattet, das Programm foilzusetzen Aber erinnern Sie sich daran, daß 
die Unterbrechungen (einschließlich BRK) den Stapel und den Stapelzeiger ver¬ 
wenden, um die Rückkehr-Adresse und den Register-Inhalt zu speichern. Bild 
14-1 zeigt eine Routine, in der BRK in einer endlosen Schleife resultiert. Der Pro¬ 
grammierer hätte diesen Haltepunkt mit einem RESET-oder Unterbrechungs- 
Signal zu löschen. 


Tabelle 14-1 6502-Unterbrechungs-Vektoren. 




•-BREAK 
JMP BREAK 


;ADRESSE FÜR BREAK-ROUTINE 
;WARTE AUF DER STELLE 


Die Unterbrechungs-Service-Routine muß einen Sprung zur Adresse 
BREAK erzwingen, wenn sie das Break-Kommando-Flag gesetzt findet 
(dies unterscheidet zwischen BRK und IRQ-Eingängen) 


Bild 14-1. Eine einfache Haltepunkt-Routine. 


Das einfachste Verfahren zum Einsetzen von Haltepunkten besteht im Ersetzen 
der ersten Bytes des Befehls durch einen BRK-Befehl, oder durch Ersetzen ei¬ 
nes Befehls mit einem JMP- oder JSR-Befehl. Der BRK-Belehl ist vorzuziehen, 
da nur ein einziges Byte ersetzt werden muß, und der Haltepunkt nicht darauf 
folgende Befehle überschreiben wird. 
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Zahlreiche Momtore besitzen die Möglichkeit des EINSETZEN VON 

Einsetzens und Entfernens von Haltepunkten HALTEPUNKTEN 

über irgendeine Art von Sprungbefehl 

Derartige Haltepunkte beeinflussen nicht die zeitliche Steuerung des Program¬ 
mes, bis der Haltepunkt ausgeführt wird. Beachten Sie jedoch, daß dieses Ver¬ 
fahren nicht arbeiten wird, wenn ein Teil oder das gesamte Programm sich in ei¬ 
nem ROM oder PROM befindet. Andere Monitore führen Haltepunkte aus, indem 
sie tatsächlich die Adressenleitungen oder den Befehlszähler in Hardware oder 
Software prüfen. Dieses Verfahren gestattet Haltepunkte an Adressen im ROM 
oder PROM, kann jedoch die zeitliche Steuerung beeinlussen, wenn die Adres¬ 
se in Software geprüft werden muß. Eine leistungsfähige Möglichkeit würde dem 
Anwender die Eingabe einer Adresse gestatten, zu der der Prozessor die Steue¬ 
rung überträgt. Eine ander Möglichkeit bestünde in einer Rückkehr, abhängig 
von einem Schalter: 


•-BRKPT ;ADRESSE FÜR HALTEPUNKT-ROUTINE 

BIT VIAORA .WARTE AUF GESCHLOSSENEN SCHALTER 

BPL BRKPT 

RTI 

Natürlich könnten andere VIA-Daten oder Steuerleitungen verwendet werden 
Erinnern Sie sich daran, daß RTI automatisch das Statusregister wiederherstellt 
und die Unterbrechung wieder freigibt. Wenn die Unterbrechung über eine VIA- 
Steuerleitung kommt, müßte die Routine auch das zugehörige Bit im Unterbre- 
chunsflag-Register löschen. 

Die Möglichkeit für einen Register-Auszug in einem Mikro- REGJSTER- 
computer ist ein Programm, das den Inhalt aller CPU-Re- AUSZUG 
gister auflistet. Diese Information ist gewöhnlich nicht di- 
rekt erhältlich. Die folgende Routine wird den Inhalt aller Register ausdrucken, 

wenn wir annehmen, daß PRTHEX den Inhalt des Akkumulators in Form zweier 
hexadezimaler Ziffern ausdruckt. Bild 14-2 ist ein Flußdiagramm des Program¬ 
mes und Bild 14-3 zeigt ein typisches Ergebnis. Wir nehmen an, daß die Routine 
die mit einem Befehl JUMP TO SUBROUTINE eingegeben wurde, die den alten 
Befehlszähler in die Spitze des Stapels speichert. Eine Unterbrechung oder ein 
BRK-Befehl wird sowohl den Befehlszähler wie das Statusregister in die Spitze 
des Stapels speichern. 
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■PLAZIERE ALLE CPU-REGISTER IN DEN STAPEL (PC BEREITS IM STAPEL) 


PHP 

PHA 

TXA 

PHA 

TYA 

PHA 

TSX 


TXA 

CLC 

ADC #6 


iBEWAHRE STATUS AUF, FALLS ERFORDER- 
; LICH (NICHT NACH IRQ) 
iBEWAHRE INHALT DES AKKUMULATORS 
: AUF 

iBEWAHRE INDEXREGISTER X AUF 

iBEWAHRE INDEXREGISTER Y AUF 

iBEWAHRE URSPRÜNGLICHEN STAPELZEI- 
i GER AUF 


iVERSETZE ZURÜCK ZUM URSPRÜNGLI- 
i CHEN WERT 


;DRUCKE INHALT DER REGISTER AUS 
iREIHENFOLGE IST S, Y, X. A, P. PC. (LOW), PC (HIGH) 


LDY 

#7 

iANZAHL DER BYTES-7 

PRNT LDA 

$0100.X 

;HOLE EIN BYTE VOM STAPEL 

JSR 

PRTHEX 

;UND DRUCKE AUS 

INX 



DEY 



BNE 

PRNT 



iSPEICHERE REGISTER VOM STAPEL ZURÜCK 


PLA 

PLA 

TAY 

PLA 

TAX 

PLA 

PLP 

RTS 


.HOLE UND LÖSCHE STAPELZEIGER 
iSPEICHERE INDEXREGISTER Y ZURÜCK 

iSPEICHERE INDEXREGISTER X ZURÜCK 

iSPEICHERE INHALT DES AKKUMULATORS 
; ZURÜCK 

iSPEICHERE STATUSREGISTER FALLS 
■ ERFORDERLICH ZURÜCK 
iSPEICHERE PC UND SP ZURÜCK 
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Bild 14-2. Flußdiagramm des Registerauszugs-Programm. 
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Bild 14-3. Ergebnisse eines typischen Register-Auszugs 


Ein Speicher-Auszug ist ein Programm, das den Inhalt des 
Speichers auf einem Ausgabegerät (wie etwa einem 
Drucker) auflistet. Dies ist ein wesentlich effizienterer Weg 
zur Prüfung von Daten-Anordnungen oder des gesamten Programmes, als nur 
das Untersuchen einzelner Stellen Es sind jedoch sehr große Speicher-Aus¬ 
züge infolge ihrer großen Menge von Informationen nicht sehr nützlich (außer 
um eine Menge Schmierzettel zu liefern) Aut einem langsamen Drucker kann 
die Ausführung auch verhältnismäßig lange dauern Kleine Speicher-Auszüge 
können jedoch dem Programmierer eine vernünftige Menge von Informationen 
liefern, die er noch ohne weiteres prüfen kann. Beziehungen, wie regelmäßige 
Wiederholungen von Datenmustern oder Versetzungen ganzer Anordnungen 
werden hierbei erkenntlich. 

Ein allgemeiner Auszug ist häufig verhältnismäßig schwierig zu schreiben. Der 
Programmierer sollte sorgfältig aut folgende Situationen achten: 

1) Die Größe des Speicherbereichs überschreitet 256 Bytes, so daß ein einzel¬ 
ner 8-Bit-Zähler nicht ausreichend sein wird. 

2) Der Abschluß-Speicherplatz ist eine Adresse, die kleiner ist als der Start- 
Speicherplatz. Dies sollte als Fehler behandelt werden, da der Anwender 
selten wünschen wird, den gesamten Speicher-Platz in einer ungewöhnli¬ 
chen Reihenfolge auszudrucken. 

Da die Geschwindigkeit des Speicher-Auszug gewöhnlich abhängig von der 
Geschwindigkeit des Ausgabegerätes ist, ist die Effizienz der Routine selten 
von Bedeutung, Das folgende Programm wird Fälle ignorieren, bei denen die 
Start Adresse größer als die End-Adresse ist und wird Blöcke beliebiger Länge 
handhaben. 

Wir nehmen an, daß sich die Startadresse in den Speicher-Adressen START 
und START+1 befindet, sowie die Endadresse in den Speicher-Adressen LAST 
und LAST+1. Wir haben angenommen, daß die Adressen START und START+1 
sich auf der Nullseite befinden, so daß deren Inhalt indirekt verwendet wer¬ 
den kann. 


SPEICHER¬ 

AUSZUG 


.DRUCKE INHALT DER SPEZIFIZIERTEN SPEICHERPLÄTZE AUS 


DUMP 

LDY 

# 0 

;HALTE OFFSET IMMER AUF NULL 

DBYTE 

LDA 

LAST 

;SIND WIR OBERHALB DER ENDADRESSE? 


CMP 

START 



LDA 

LAST+1 



SBC 

START+1 



BCC 

DONE 

,JA, AUSZUG BEENDET 


LDA 

(START),Y 

;NEIN, HOLE DEN INHALT DES NÄCHSTEN 




, SPEICHERPLATZES 


JSR 

PRTHEX 

.DRUCKE INHALT ALS 2 HEXZIFFERN AUS 


INC 

START 

.INKREMENTIERE SPEICHERZEIGER 


BNE 

DBYTE 



INC 

START+1 



JMP 

DBYTE 


DONE 

RTS 




Es gibt keinen direkten Weg, um den 16-Bit-Vergleich und Inkrementierung 
auszuführen, das durch diese Routine erforderlich ist. 
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Bild 14-4 zeigt den Ausdruck eines Auszugs der Speicherplätze 1000 bis 
101F. 
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Bild 14-4. Ergebnisse eines typischen Speicher Auszugs 


Diese Routine arbeitet ordnungsgemäß in dem Fall, bei dem Start- und End- 
Speicherplätze gleich sind, (Versuchen Sie es!) Sie werden die Ergebnisse sorg¬ 
fältig zu interpretieren haben, wenn der Bereich des Auszugs den Stapel bein¬ 
haltet, da das Auszugs-Unterprogramm selbst den Stapel verwendet. PRTHEX 
kann auch Speicher- und Stapel-Plätze ändern. 

Bei einem Speicherauszug können die Daten in einer Vielzahl unterschiedlicher 
Allen dargestellt werden. Gebräuchliche Formen sind ASCII-Zeichen oder 
Paare von hexadezimalen Ziffern für 8-Bit-Werte und vier hexadezimale Ziffern 
für 16-Bit-Werte Das Format sollte entsprechend der vorgesehenen Verwen¬ 
dung des Auszuges gewählt werden. Es ist nahezu immer einfacher einen Ob¬ 
jektcode-Auszug zu interpretieren, wenn er in hexadezimaler Form anstatt in 
ASCII-Form dargestellt wird. 

Ein gebräuchliches und nützliches Auszugs-Format ist hier dargestellt: 

1000 5468 652064756070 Der Auszug 

Jede Zeile besteht aus drei Teilen. Die Zeile beginnt mit der hexadezimalen 
Adresse der ersten Bytes, das auf der Zeile dargestellt wird. Der Adresse folgen 
acht oder 16 Bytes in hexadezimaler Form Zuletzt erfolgt die ASCII-Darstellung 
der gleichen acht oder 16 Bytes. Versuchen Sie das Speicherauszugs-Pro- 
gramm so neu zu schreiben, daß es die Adressen und die ASCII-Zeichen sowie 
die hexadezimale Form der Speicherinhaltes druckt. 


FORTSCHRITTLICHERE FEHLERSUCH-HILFSMITTEL 

Die fortschrittlichsten Hilfsmittel für die Fehlersuche, die am meisten verwen¬ 
det werden sind: 

• Simulatorprogramme zum Prüfen der Software 

• Logik-Analysatoren zum Prüfen der Signale und der zeitlichen Steuerung 

Von diesen beiden Hilfsmitteln existieren zahlreiche Varianten und wir werden 
nur die Standard-Eigenschaften besprechen. 


Der Simulator stellt das Computer-Äquivalent des "Blei¬ 
stift- und Papier-Verfahrens" dar. Es handelt sich um ein 
Computerprogramm, das den Arbeitszyklus eines anderen Computers durch¬ 
läuft, wobei es den Inhalt aller Register, Flags und Speicherplätze verfolgt. Wir 

könnten dies natürlich manuell ausführen, was jedoch sehr mühsam wäre und 
eine sorgfältige Beobachtung des Einflusses jedes Befehls voraussetzen würde. 
Das Simulatorprogramm dagegen wird niemals müde oder veiwirrt, und vergißt 
keinen Befehl oder Register. 

Die meisten Simulatoren sind große FORTRAN-Programme. Sie können gekauft 
oder auf Time-Sharing-Diensten verwendet werden. Der 6502-Simulator ist in 
zahlreichen Versionen von verschiedenen Lieferanten erhältlich. 

Typische Simulator-Eigenschaften sind: 

1) Eine Haltepunkt-Möglichkeit. Gewöhnlich können Haltepunkte gesetzt wer¬ 
den. nachdem eine bestimmte Anzahl von Zyklen ausgeführt wurde, wenn 
auf einen Speicherplatz oder einen Satz von Speicherplätzen Bezug genom¬ 
men wurde, wenn der Inhalt eines Speicherplatzes oder einer Anzahl von 
Speicherplätzen geändert wurde oder bei anderen Bedingungen. 

2) Die Möglichkeit für Register- und Speicher-Auszüge, die Werte der Spei¬ 
cherplätze. Register und E/A-Ports anzeigen 

3) Eine Ablaufverfoigung (trace), die den Inhalt spezieller Register oder Spei¬ 
cherplätze ausdruckt, wann immer das Programm diese ändert oder verwen¬ 
det. 

4) Eine Lade-Möglichkeit, die Ihnen das Setzen von Anfangswerten oder deren 
Änderung während der Simulation gestattet. 


SOFTWARE¬ 

SIMULATOR 


Einige Simulatoren können auch Eingaben/Ausgaben, Unterbrechungen und so¬ 
gar DMA simulieren. 

Das Simulator-Programm besitzt zahlreiche Vorteile: 

1) Es kann eine vollständige Beschreibung des Computer-Status liefern, da 
das Simulator-Programm nicht durch Anschlußprobleme oder andere physi¬ 
kalische Probleme eingeschränkt ist. 

2) Es kann Haltepunkte, Auszüge, Tracer (Ablaufverfolger) und andere Möglich¬ 
keiten liefern, ohne iregendeinen Teil des Speichers oder Steuersystems des 
Prozessors zu verwenden. Diese Möglichkeiten werden daher das Anwen¬ 
derprogramm nicht stören. 

3) Programme, Startpunkte und andere Bedingungen sind leicht zu ändern. 
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4) Alle Möglichkeiten eines großen Computers, einschließlich peripherer Ge¬ 
räte und Software sind für den Mikroprozessor-Entwickler verfügbar. 

Andererseits ist das Simulator-Programm durch seine Software-Grundlage 
und seine Trennung vom realen Mikrocomputer begrenzt. Die wesentlichsten 
Grenzen sind: 

1) Das Simulator-Programm kann nicht bei zeitlichen Steuerproblemen helfen, 
da es wesentlich langsamer als in Echtzeit arbeitet und keine tatsächliche 
Hardware oder Interfaces nachbildet. 

2) Das Simulator-Programm kann das Eingabe/Ausgabe-System nicht voll er¬ 
setzen. 

3) Das Simulator-Programm ist gewöhnlich verhältnismäßig langsam. Die Wie¬ 
dergabe einer Sekunde echter Prozessorzeit kann Stunden von Computer¬ 
zeit erfordern. Die Verwendung des Simulators kann ziemlich aufwendig wer¬ 
den. 

Das Simulator-Programm stellt die Software-Seite der Fehlersuche dar. Es be¬ 
sitzt die typischen Vorteile und Grenzen der gesamten Software-Lösung. Das 
Simulator-Programm kann einen Einblick in die Programmlogik und ander 
Software-Probleme geben, kann jedoch nicht bei der zeitlichen Steuerung, 
E/A- und anderen Hardware-Problemen helfen. 

Der Logik- oder Mikroprozessor-Analysator ist die Hard- LOGIG- 
ware-Lösung für die Fehlersuche. Grundlegend ist der An- ANALYSATOR 

alysator die parallele digitale Version des Standard-Oszil- - 

lografen. Der Analysator stellt Informationen in binär, hexadezimal oder Mne¬ 
monik-Form auf einer Kathodenstrahlröhre dar, und besitzt eine Vielzahl von 
Trigger-Möglichkeiten, Schwellwert-Einstellungen und Eingängen. Die meisten 
Analysatoren besitzen einen Speicher, so daß sie auch den vorhergehenden In¬ 
halt der Busse darstellen können. 

Das Standard-Veifahren besteht im Einstellen der Triggerung auf ein bestimm¬ 
tes Ereignis, etwa dem Auftreten einer bestimmten Adresse auf dem Adressen¬ 
bus oder eines Befehls auf dem Datenbus. Man könnte zum Beispiel den Ana¬ 
lysator triggern, wenn der Mikrocomputer versucht, Daten in eine bestimmte 
Adresse zu speichern oder einen Eingabe oder Ausgabebefehl ausführt. Man 
kann sich dann die Folge der Vorgänge ansehen. die vor dem Haltepunkt auftre- 
ten. Übliche Probleme, die man auf diese Weise finden kann, sind kurze Span- 
nungssp'itzen (glitches), falsche Signal-Sequenzen, überlappende Impulse und 
andere Fehler in den zeitlichen Steuersignalen. Natürlich könnte ein Software- 
Simulator nicht zur Feststellung derartiger Fehler verwendet werden, ebenso¬ 
wenig, wie ein Logik-Analysator zum Aufsuchen von Fehlem in der Programm¬ 
logik dienlich wäre. _ 

WICHTIGE 

Logik-Analysatoren variieren in zahlreichen EIGENSCHAFTEN 

Punkten. Einige hiervon sind: VON LOGIK- 

ANALYSATOREN 

1) Anzahl der Eingangsleitungen. 

Zur Überwachung eines 8 Bit-Datenbusses und eines 1 6-Bit- 
Adressenbusses sind wenigstens 24 hiervon erforderlich. Weitere werden für 
die Steuersignale, Takt und andere wichtige Eingangs-Signale benötigt. 
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2) Größe des Speichers. Jeder vorausgehende Zustand, der aufbewahrt werden 
soll, wird mehrere Bytes belegen. 

3) Maximale Frequenz. Sie muß mehrere MHz betragen, um auch die schnell¬ 
sten Prozessoren untersuchen zu können 

4) Minimale Signalbreite (wichtig für das Aufspüren von Spannungsspitzen) 

5) Art und Anzahl der zulässigen Trigger-Vorgänge. Wichtige Eigenschaften 
sind Vor- und Nach-Triggerverzögerungen. Diese gestatten dem Anwender 
die Anzeige von Vorgängen, die vor oder nach dem Trigger-Ereignis auftre- 
ten. 

6) Ve/fahren zur Verbindung mit dem Mikrocomputer. Diese können ziemlich 
komplexe Interfaces erfordern. 

7) Anzahl der Anzeigekanäle. 

8) Binäre, hexadezimale oder mnemonische Anzeigen. 

9) Anzeigeformate. 

10) Anforderung an die Dauer der Aufbewahrung des Signals 

11) Kapazität der Tastköpfe. 

12) Einfache oder doppelte Ansprech-Schwellen. 

Alle diese Faktoren sind wichtig bein Vergleich verschiedener Logik- und Mikro¬ 
prozessor-Analysatoren, da diese Instrumente noch neu und nicht standardi¬ 
siert sind. Eine verwirrende Vielfalt von Produkten ist bereits erhältlich, und die¬ 
se Vielfalt wird in Zukunft noch zunehmen. 

Logik-Analysatoren sind natürlich nur filr Systeme mit komplexer zeitlicher 
Steuerung erforderlich. Einfache Anwendungen mit langsamen peripheren Ge¬ 
räten besitzen wenig Hardware-Probleme, die der Entwickler nicht mit einem 
Standard-Ozillografen lösen könnte. 
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FEHLERSUCHE MIT PRÜFLISTEN 

Der Entwickler kann möglicherweise nicht ein gesamtes Programm manuell 
überprüfen. Es gibt jedoch bestimmte Schwerpunkte, die leicht untersucht 
werden können. Sie können ein systematisches manuelles Suchen verwenden, 
um eine große Anzahl von Fehlern aufzufinden, ohne hierzu irgendwelche Feh- 

lersuch-Hilfsmittel zu benötigen. _ 

WAS ENTHÄLT 

Die Frage ist, wo die größten Anstrengungen zu EINE CHECKLISTE 

machen sind. Die Antwort lautet, an Punkten, -- 

die entweder mit einer Ja-Nein-Aussage oder mit einer einfachen arithmeti¬ 
schen Berechnung behandelt werden können. Versuchen Sie nicht, komplexe 
arithmetische Berechnungen auszuführen, die Flags zu verfolgen oder jeden 
möglichen Fall zu untersuchen. Beschränken Sie Ihre Überprüfungen auf Gebie¬ 
te, die leicht zu überblicken sind. Lösen Sie die komplexen Probleme mit Hilfe 
verschiedener Fehlersuch-Hilfsmittel. Gehen Sie jedoch systematisch vor. Stel¬ 
len Sie sich Ihre Checkliste auf und vergewissern Sie sich, daß das Programm 
die grundlegenden Operationen korrekt ausführt. 

Der erste Schritt besteht im Vergleichen des Flußdiagramms oder des struktu¬ 
rierten Programmes mit dem tatsächlichen Code. Vergewissern Sie sich, daß 
alles was in einem hiervon aufscheint, auch im anderen zu finden ist. Eine ein¬ 
fache Checkliste wird diese Aufgabe ertüllen. Es kann sehr leicht Vorkommen, 
daß man eine Verzweigung oder einen Verarbeitungsabschnitt vollkommen 
übersieht. 

Als nächstes konzentrieren Sie sich auf die Programmschleifen. Vergewissern 
Sie sich, daß alle Register und Speicherplätze innerhalb der Schleifen vor deren 
Verwendung initialisiert wurden. Dies ist eine häufige Fehlerquelle. Wiederum 
wird eine einfache Checkliste ausreichen. 

Nun sehen Sie sich jede bedingte Verzweigung an. Wählen Sie ein Beispiel, das 
eine Verzweigung bewirken sollte und eines, bei dem dies nicht der Fall ist. Ver¬ 
suchen Sie beide hiervon. Erfolgt die Verzweigung korrekt oder umgekehrt? 
Wenn die Verzweigung eine Prüfung beinhaltet, ob sich eine Zahl oberhalb oder 
unterhalb eines Schwellwertes befindet, versuchen Sie den Fall mit der Gleich¬ 
heit. Tritt die korrekte Verzweigung auf? Vergewissern Sie sich, daß Ihre Wahl 
mit der Aufgaben-Oefinition übereinstimmt. 

Sehen Sie sich die Schleifen als Ganzes an. Versuchen Sie die erste und letzte 
Wiederholung manuell. Diese sind häufig sehr mühsame spezielle Fälle. Was 
geschieht, wenn die Anzahl der Wiederholungen null ist, d.h., es liegen keine 
Daten vor. oder die Tabelle besitzt keine Elemente? Läuft das Programm hier 
korrekt durch? Programme werden häufig eine Wiederholung unnötig ausfüh¬ 
ren, oder noch ungünstiger, Zahler nach Null dekrementieren, bevor sie diese 
geprüft haben. 


an Han hL«! ? c h let2 ‘ e " Anweisung. Nehmen Sie (hoffnungsvoll) nicht 
r» Ittlr de2erste Fehler auch der einzige in diesem Programm ist. Die manuel- 
e Überprüfung gestattet Ihnen den maximalen Nutzen aus den Fehlersuch-Ab- 
werd" ZU 9eWlnnen ’ da S,e ne henbei gleich zahlreiche einfache Fehler los- 


Ein kurzer Überblick über die Fragen der manuel¬ 
len Überprüfung wäre: 

1) Befindet sich Jedes Element der Programm- 
Di im Programm (und umgekehrt lür Dokumentationszwecke)? 

Z) Sind alle Register und Speicherplätze, die innerhalb von Schleifen verwendet 
werden, vor ihrer Verwendung initialisiert worden? 

3) Sind alle bedingten Verzweigungen richtig? 

4) Beginnen und enden alle Schleifen ordnungsgemäß? 

5) Werden Gleichheits-Fälle korrekt verarbeitet? 

6) Werden alle trivialen Fälle ordnungsgemäß verarbeitet? 


FRAGEN BEI 
MANUELLER 
PRÜFUNG 
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SUCHEN VON FEHLERN 


Andere Probleme auf die zu achten sind: 


Natürlich arbeiten häufig, ungeachtet dieser Vorsichts¬ 
maßnahmen (es sei denn, Sie haben einige hiervon über¬ 
gangen), Programme trotzdem nicht. Der Entwickler steht 
vor der Aufgabe, diese Fehler zu finden. Man kann mit der Prüfliste beginnen, 
wenn diese nicht bereits verwendet wurde. Einige der Fehler, die Sie vielleicht 
noch nicht eliminiert haben sind: 


HÄUFIGE 

FEHLER 


1) Fehler durch mangelnde Initialisierung von Variablen wie Zahler, Zeiger, 
Summen, Indizes etc. Nehmen Sie nicht an, daß Register, Speicherplätze 
oder Flags notwendigerweise Null beinhalten, bevor sie verwendet werden, 

2) Umkehrung eines bedingten Sprunges, wie die Verwendung vori Verzweige 
wenn Übertrag gesetzt", wenn Sie meinen "Verzweige wenn Übertrag ge¬ 
löscht"- Achten Sie besonders aut die Tatsache, daß der 6502 (anders als bei 
den meisten Mikroprozessoren) den Übertrag als ein mvertiertes Borgen 
nach einer Subtraktion oder nach einem Vergleich veiwendet So ist der Ein 
fluß eines Vergleiches oder einer Subtraktion wie tolgt: (A ist der Inhalt des 
Akkumulators, M der Inhalt des Speicherplatzes): 


Nuil-Flag -1 wenn A - M 
Nuil-Flag = 0 wenn A ^ M 
Übertrags-Flag - 1 wenn A ^ M 
Übertrags-Flag - 0 wenn A < M 


Beachten Sie besonders, daß Üb ertrag = 1 wenn A - M (der Gleichheits-Fall). 
Hier bedeutet "Verzweige wenn Übertrag gesetzt" einen Sprung, wenn A > M 
und "Verzweige wenn Über rag gelöscht" bedeutet einen Sprung, wenn A < M. 
Wenn Sie den Gleichheits-Fall auf der anderen Seite wünschen, versuchen Sie, 
die Rollen von A und M zu vertauschen, oder addieren Sie 1 zu M, Wenn Sie 
beispielsweise einen Sprung für den Fall A ^ 10 wollen, so veiwenden Sie 


CMP #10 
BCC ADDR 

Wenn Sie andereseits einen Sprung tür den Fall A > 10 wollen, verwenden Sie: 


CMP #10 
BCS ADDR 

3) Weiterstellen der Zähler und Zeiger an der falschen Stelle oder überhaupt 
nicht. Vergewissern Sie sich, ob es keine Wege durch eine Schleife gibt, bei 
denen entweder die Betehletür das Weiterstellen übersprungen oder wieder¬ 
holt werden, 

4) Ausfallen von korrekten Durchläufen in trivialen Fällen, wie keine Daten in 
einem Putter, keine Tests auszuiühren, oder keine Eingaben beider Übertra¬ 
gung. Nehmen Sie niemals an, daß der derartige Fälle nie auttreten, außer 
das Programm hat diese Fälle speziell eliminiert. 




5) Umkehrung der Reihenfolge von Operanden. 

Erinnern Sie sich daran, daß zum Beispiel der TAX-Befehl A zu X bringt, je¬ 
doch nicht umgekehrt. 

6) Änderung von Bedingungsflags, bevor sie verwendet werden. Erinnern Sie 
sich daran, daß alle Befehle, außer Speicher- und Verzweigungsbetehlen 
die Flags beeinflussen, insbesondere Vorzeichen- und Null-Flags. Erinnern 
Sie sich auch daran, daß PLP und RTI alle Flags ändern können. 

7) Verwechslung des Indexregisters und des indizierten Speicherplatzes. 
Beachten Sie, daß INX und INY das Indexregister inkrementieren, während 
INC ADDR.X und andere ähnliche Befehle den Inhalt der indizierten Spei¬ 
cherplatzes inkrementieren. 

8) Verwechslung von Daten und Adressen. 

Erinnern Sie sich daran, daß LDA #$40 in A die Zahl 40, t lädt, während 
LDA $40 den Akkumulator mit dem Inhalt des Speicherplatzes 0040« lädt. 
Seien Sie vorsichtig, wenn Sie die vonndizierre und nachindizierte Adressie¬ 
rung verwenden, bei denen ein Paar von Adressen aut der Nullseite die tat¬ 
sächliche oder Basis-Adresse der Daten enthält. 

9) Zufällige Re-Initialisierung eines Registers oder Speicherplatzes. 
Vergewissern Sie sich, daß kein Sprungbefehl die Steuerung zurück zu Ini¬ 
tialisierungs-Anweisungen transferiert. 

10) Verwechslung von Zahlen und Zeichen. 

Erinnern Sie sich daran, daß die ASCII und EBCDIC-Darstellungen von Zit¬ 
tern sich von den Ziffern selbst unterscheicen. Beispielsweise ist ASCII 7 
gleich 37, e , wogegen 07« das Klingelzeichen (BELL) in ASCII ist 

11) Verwechslung von Binär- und Dezimalzahlen. 

Erinnern Sie sich daran, daß die BCD-Darstellung einer Zahl verschieden 
von seiner Binär-Darstellung ist Beispielsweise ist BCD 36 gleich binär 54 
(versuchen Sie es). 

12) Umkehrung der Reihenfolge bei einer Subtraktion. Seien Sie auch bei an¬ 
deren Operationen sehr vorsichtig (wie der Division), daß Sie diese nicht 
vertauschen. Erinnern Sie sich daran, daß SBC, CMP, CPX und CPY alle 
den Inhalt des adressierten Speicherplatzes vom Inhalt des Akkumulators 
oder Indexregisters subtrahieren. 

13) Ignorieren der Effekte von Unterprogrammen und Makros. Nehmen Sie 
nicht an, daß das Aufrufen von Unterprogrammen oder Bezugnahme auf 
Makros die Flags, Register oder Speicherplätze nicht ändert. Vergewissern 
Sie sich genau, welche Auswirkungen sie haben. Beachten Sie, daß es sehr 
wichtig ist, diese Einflüsse schriftlich festzuhalten. 

14) Falsche Verwendung von Schiebebefehlen. 

Erinnern Sie sich an die genauen Auswirkungen von ASL, LSR, ROL 
und ROR Diese sind I-Bit-Verschiebungen, die das Übertrags-, Vorzei¬ 
chen- und Nuii-Fiag beeinflussen ASL und LSR löschen beide das leere Bit. 
ROR und ROL sind zirkulare Verschiebungen, die den Übertrag mit ein¬ 
schließen. Erinnern Sie sich daran, daß das Übertrags-, Vorzeichen- und 
Null-Flag beeinf lußt wird, auch wenn diese Befehle auf Daten in einem Spei¬ 
cherplatz angewendet werden. 
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15) Falsches Zählen der Länge einer Anordnung. 

Erinnern Sie sich daran, daß es fünf (nicht vier) Speicherplätze gibt, die in 
den Adressen 0300 bis 0304 (einschließlich) enthalten sind 

16) Verwechslung von 8-und 1 6-Bit-Größen. 

Adressen sind tatsächlich 1 6 Bits lang. Das einzige Register des 6502, das 
eine vollständige Adresse aufbewahren kann, ist der Befehlszähler. 

17) Vergessen, daß 16-Bit-Zahlen zwei Speicherplätze belegen. 

Absolute direkte oder absolute indizieite Adressierung belegt zwei Spei¬ 
cherplätze, so wie es die Adressen machen, die auf der Nullseite gespei¬ 
chert sind, zur Verwendung in der nachindizierten oder vorindizfeiten 
Adressierung. Oer Befehlszähler belegt auch zwei Speicherplätze, wenn er 
im Stapel gespeichert wird. Beachten Sie. daß bei der vorindizierten und na¬ 
chindizierten Adressierung zwei Speicherplätze verwendet werden, obwohl 
nur einer spezifiziert wird. Die Adresse, die unmittelbar der einen spezifier- 
ten folgt, wird auch zum Aufbewahren der indirekten Adresse benötigt. 

18) Verwechseln des Stapels und des Stapelzeigers. 

Der Befehl TXS beeinflußt den Stapelzeiger, nicht den Inhalt des Stapels. 
PHA, PHP und PLP transferieren Daten zum oder vom Stapel. Erinnern Sie 
sich daran, daß JSR, RTS, RTI und BRK ebenfalls den Stapel verwenden. Er¬ 
innern Sie sich ferner daran, daß Sie den Stapelzeiger initialisieren müssen, 
bevor Sie irgend ein Unterprogramm aufrufen oder Unterbrechungen ge¬ 
statten. Der Stapel des 6502 liegt immer auf Seite 1; nur die 8 letzten signifi¬ 
kanten Bits der Stapeladresse liegen tatsächlich im Stapelzeiger. 

19) Änderung eines Registers oder Speicherplatzes vor dessen Verwendung. 
Erinnern Sie sich daran, daß LDA, STA, LDX, STX, LDY, STY, TAX, TXA etc. 
den Inhalt des Bestimmungsortes (jedoch nicht der Quelle) ändern. 

20) Vergessen des Transferierens der Steuerung nach Abschnitten des Pro¬ 
grammes, die in bestimmten Situationen nicht ausgeführt werden sollten. 
Erinnern Sie sich daran, daß der Computer sequentiell durch den Pro¬ 
grammspeicher gehen wird, außer es wird ihm speziell anders vorge¬ 
schrieben. 

21) Vergessen, daß der Übertrag immer in Additions- und Subtraktions-Opera¬ 
tionen enthalten ist. 

Der 6502 besitzt nur Befehle "Addiere mit Übertrag" und “Subtrahiere mit 
Borgen", anders als bei zahlreichen anderen Prozessoren, die reguläre Ad¬ 
ditions- und Subtraktionsbefehle besitzen, die keinen Übertrag beinhalten. 
Der Übertrag muß ausdrücklich vor einer Addition gelöscht und vor einer 
Subtraktion gesetzt werden, wenn sein Weit nicht von der Operation beein¬ 
flußt wird. Beachten Sie jedoch, daß die Vergleichsbefehle (CMP, CPX, 
CPY) keinen Übertrag beinhalten. 

22) Invertierendes Vorzeichens des Übertrags bei einer Subtraktion. 

Bei Subtraktions- und Vergleichsbefehlen isf der sich ergebende Ubetrag 
ein invertiertes "Borgen", d.h,, der Übertrag wird gesetzt, wenn kein Borgen 
erforderlich ist. Entsprechend subtrahiert der Befehl "Subtrahiere mit Bor¬ 
gen” den invertierten Übertrag (1 - Übetrag), zusammen mit dem Inhalt des 
spezifizierten Speicherplatzes. 

23) Falsche Verwendung der dezimalen Betriebsart. 

Wenn das Flag "Decimal Mode" gesetzt ist, sind alle arithmetischen Ergeb¬ 
nisse dezimal. Daher muß das Flag ausdrücklich gelöscht werden, wenn die 
Dezimal-Operationen abgeschlossen sind. Andernfalls wird es die Ergeb¬ 
nisse von Operationen ändern, die nicht in dezimal ausgeführt werden sol¬ 
len. Beachten Sie, daß alle Wege, die einen Befehl "Setze Dezimal-Betriebs¬ 
art" beinhalten, auch einen Befehl "Lösche Dezimai-Betriebsart" haben 
müssen Seien Sie besonders sorgfältig bei einem "Fall-through" und bei 
Austritten infolge eines Fehlers. 


24) Falsche Verwendung des Befehls "Bit-Test". 

Beachten Sie, daß der Bit-Test-Befehl das Vorzeichen- und Überlauf-Flag 
entsprechend der Bits 7 und 6 des geprüften Speicherplatzes setzt, ohne 
Rücksicht auf den Inhalt des Akkumulators. Dieser Befehl ist sehr bequem 
zum Testen der Statusbits im PIA 6502 und anderen Bitprüf-Operationen, 
erfordert jedoch sorgfältige Dokumentation, da seine Ergebnisse oft unklar 
füreinenLesersein können 


Unterbrechungs-gesteuerte Programme sind be¬ 
sonders schwierig fehlerfrei zu machen, da Feh¬ 
ler zufällig auftreten können. Wenn zum Beispiel 
das Programm die Unterbrechungen einige Be¬ 
fehle zu früh freigibt, wird ein Fehler nur dann auf¬ 
treten, wenn eine Unterbrechung gerade bei Aus¬ 
führung dieser wenigen Befehle empfangen wird- 
In der Tat können Sie für gewöhnlich annehmen, daß zufällig auftretende Feh¬ 
ler durch das Unterbrechungssystem bewirkt werden. Typische Fehler in un- 
terbrechungs-gesteuerten Programmen sind: 

1) Vergessen der Wieder-Freigabe von Unterbrechungen nach der Annahme 
und Bedienung einer Unterbrechung. 

Der Prozessor sperrt das Unterbrechungssystem automatisch bei RESET 
oder bei der Annahme einer Unterbrechung. Vergewissern Sie sich, daß kei¬ 
ne möglichen Sequenzen versäumen, die Unterbrechung wieder freizuge¬ 
ben, 

2) Verwendung des Akkumulators bevor er aufbewahrt wird. D.h. PHA muß je¬ 
der Operation vorausgehen, die den Akkumulator ändert 

3) Vergessen des Aufbewahrens und Zurückspeicherns des Akkumulators. 

4) Zurückspeichern der Register in falscher Reihenfolge. 

Wenn die Reihenfolge, in der die Register aufbewahrt wurden, war; 

PHA ;BEWÄHRE AKKUMULATOR-INHALT AUF 

TXA ;BEWAHRE INDEXREGISTER X AUF 

PHA 

TYA iBEWAHRE INDEXREGISTER Y AUF 

PHA 

so sollte die Reihenfolge des Zurückspeicherns sein: 

PLA SPEICHERE INDEXREGISTER Y ZURÜCK 

TAY 

PLA SPEICHERE INDEXREGISTER X ZURÜCK 

TAX 

PLA SPEICHERE AKKUMULATOR-INHALT ZURÜCK 

5) Freigabe von Unterbrechungen, bevor alle erforderlichen Bedingungen ein¬ 
gerichtet wurden, wie Priorität, Flags, PIA und VIA-Konfigurationen, Zeiger, 
Zähler, etc. Eine Checkliste kann hier hellen. 

6 ) Belassen von Ergebnissen in Register und deren Zerstörung beim Rück¬ 
speicher-Vorgang. 

Wie früher erwähnt sollten die Register nicht zum Transferieren von Informa¬ 
tionen zwischen dem Programm und den Unterbrechungs-Serviceroutinen 
verwendet werden. 


FEHLERSUCHEIN 

UNTERBRECHUNGS¬ 

GESTEUERTEN 

PROGRAMMEN 
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7) Vergessen, daß die Unterbrechungen (einschließlich BRK) den alten 
Befehlszähler und das Statusregister im Speicher lassen, ob Sie diesen ver¬ 
wenden oder nicht. 

Sie müssen den Stapelzeiger reininitialisieren oder auf den neuesten Stand 
bringen. 

8) Ignorieren der Möglichkeit, daß in die Servicerroutine mit gesetztem Flag 
für die Dezimal-Betriebsart eingetreten wird. 

Sie müssen einen CLD-Befehl in die Service-Routine einschließen, wenn die¬ 
se Möglichkeit vorkommt Beachten Sie, daß RTI automatisch den ursprüngli¬ 
chen Zustand des Flags am Ende der Serviceroutine wiederherstellen wird. 

9) Nicht-Freigeben der Unterbrechung während Mehr-Wort-Transfers oder Be¬ 
fehlssequenzen. 

Achten Sie sorgfältig auf Situationen, bei denen Unterbrechungs Service¬ 
routinen die gleichen Speicherplätze wie das Programm veiwenden könnte 

Hoffentlich gibt Ihnen diese Liste annähernd eine Vorstellung worauf Sie ach¬ 
ten sollten. Unglücklicherweise kann ein noch so systematisches Fehlersu¬ 
chen noch genügend ungelöste Probleme zurücklassen, speziell wenn Unter¬ 
brechungen im Programm Vorkommen 3 . 



Bild 14-5. Flußdiagramm derdezimal in Sieben-Segment-Umwandlung 


Fehlersuch-Beispiel 1: Dezimal/Sieben-Segment-Umwandlung 


Das Programm wandelt eine Dezimalzahl im 
Speicherplatz 0040 in einen Sieben-Segment¬ 
code im Speicherplatz 0041 um. Es steuert die 
Anzeige dunkel, wenn der Speicherplatz 0040 
keine Dezimalzahl enthält. 


FEHLERSUCHE IN 
EINEM CODE- 
UMWANDLUNGS¬ 
PROGRAMM 


Anfängliches Programm (vom Flußdiagramm in Bild 14-5): 



LDX 

#$40 


CPX 

#9 


BCC 

DONE 


LDAA 

(SSEGX) 

DONE 

BRK 


SSEG 

.BYTE 



BYTE 

.BYTE 


;HOLE DATEN 

;SIND DATEN GRÖSSER ALS 9? 
;JA, ERLEDIGT 

;HOLE ELEMENTE VON TABELLE 

$3F,S06,$5B,$4F 1 $66 

$6D,$7D,$07,$7D,$6F 


Unter Verwendung der Checkliste sind wir imstande, folgende Fehler aufzu¬ 
finden: 

1) Der Block, der das Ergebnis löschte, wurde entfernt. 

2) Die bedingte Verzweigung war falsch. 

Wenn zum Beispiel die Daten null sind, so löscht CPX #9 den Übertrag, da 
0 < 9 und ein "Borgen" erforderlich ist. Der Sprung mit der entgegegesetzten 
Bedingung jedoch, (d.h ., BCS DONE) erzeugt noch nicht das richtige Ergebnis. 
Nun verarbeitet das Programm den Gleichheitsfall inkorrekt da, wenn die Daten 
9 sind, der Befehl CMX #9 den Übertrag löscht und einen Sprung verursacht. 
Die richtige Version ist: 

CPX #10 ;SIND DATEN EINE DEZIMALZAHL? 

BCS DONE ;NEIN, BEWAHRE FEHLERCODE AUF 


Zweites Programm: 



LDA 

#0 

HOLE CODE FÜR BLANK-(LEER) ZEICHEN 
FÜR DIE ANZEIGE 


LDX 

#$40 

HOLE DATEN 


CPX 

#10 

SIND DATEN EINE DEZIMALZAHL? 


BCS 

DONE 

NEIN, BEWAHRE FEHLERCODE AUF 


LDA 

(SSEG.X) 

HOLE ELEMENT VON TABELLE 

DONE 

STA 

BRK 

$41 

BEWAHRE SIEBEN-SEGMENT- ODER 
FEHLERCODEAUF 

SSEG 

BYTE 

$3F,$06,$5B,$4F,$66 


.BYTE 

$6D,$7D,$07,$7D,$6F 


Diese Version wurde manuell mit Erfolg geprüft. 

Da das Programm einfach war, wurde es als nächstes mit Einzelschritten mit 
realen Daten durchlaufen. Die für den Versuch gewählten Daten waren: 
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0 (die kleinste Zahl) 

9 (die größte Zahl) 

10 (ein Grenzfall) 

6Bi6 (willkürlich) 

Der erste Versuch geschah mit Null im Speicherplatz 0040. Der erste Fehler war 
offensichtlich - LDX# $40, lud die Zahl 40 in X, nicht den Inhalt des Speicher¬ 
platzes 0040 Der richtige Befehl war LDX $40 (direkte anstatt unmittelbare 
Adressierung). Nachdem diese Korrektur ausgeführt wurde, arbeitete das Pro¬ 
gramm weiter mit keinen augenscheinlichen Fehlern, bis es den Befehl 
LDA (SSEG.X) auszuführen versuchte 

Der Inhalt des Adressenbusses während des Holens der Daten war 063F, eine 
Adresse, die bisher nicht verwendet wurde. Offensichtlich ging irgend etwas 
falsch. 

Es ist nun Zeit für weitgehende manuelle Prüfung. Da wir wußten, daß BCS 
DONE korrekt war, lag der Fehler offensichtlich im LDA-Befehl. Eine manuelle 
Prüfung zeigte: 

LDA (SSEG.X) addiert den Inhalt des Indexregisters X zur Nullseiten-Adresse 
SSEG und verwendet die Summe, um die Adresse zu holen, die die tatsächli¬ 
chen Daten enthalten. Im vorliegenden Fall, da das Register X Null enthält, liegt 
die indirekte Adresse im Speicherplatz SSEG und SSEG+1. d.h., sie ist 063F. Der 
Befehl holt daher eine Adresse aus einer Tabelle, die aus Daten besteht Der 
richtige Befehl ist LDA SSEG.X -wir wollen Daten von der Tabelle holen, nicht 
die Adresse der Daten 

Auch mit dieser Berichtigung erzeugte das Programm ein Ergebnis mit Null, an¬ 
statt des erwarteten 3F. Der Fehler lag offensichtlich im letzten Befehl - er sollte 
STA $41 und nicht STX $41 sein. Beachten Sie, wie wichtig es ist, das Pro¬ 
gramm wirklich bis zum Ende zu veifolgen, anslalt nach dem scheinbar letzten 
Fehler aufzuhören. 

Das revidierte Programm war nun: 

Drittes Programm: 

LDA #0 ;HOLE FEHLER CODE FÜR DIE ANZEIGE 

LDX $40 ;HOLE DATEN 

CPX # 10 ;SIND DIE DATEN EINE DEZIMALZAHL? 

BCS DONE ;NEIN, BEWAHRE FEHLERCODE AUF 

LDA SSEG.X ;HOLE ELEMENT VON TABELLE 

STA $41 ;BEWAHRE S1EBEN-SEGMENT-CODE ODER 

; FEHLERCODE AUF 

DONE BRK 

SSEG BYTE $3F,$06.$5B.$4F.$66 

BYTE $6D,$7D,$07.$7D.$6F 

Dieses Programm erzeugte die folgenden Ergebnisse: 

Daten Ergebnis 

00 3F 

09 6F 

0A 6F 

6B 6F 
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Dieses Programm löschte nicht das Ergebnis, wenn die Daten un¬ 
gültig waren, d.h., größer als 9. Das Programm speichert niemals den "Blank- 
Code". da die Bestimmungsadresse DONE an der falschen Stelle lag - sie soll¬ 
ten dem Befehl STA $41 zugeordnet werden. Nachdem diese Korrekturen aus¬ 
geführt wurden, erbrachte das Programm korrekte Resultate für alle Testfälle. 


Da das Programm einfach war, könnte es tür alle Dezimalziffem geprüft werden. 
Die Ergebnisse wären: 


Daten 

0 

1 

2 

3 

4 

5 

6 

7 

8 
9 



Beachten Sie, daß das Ergebnis für die zahl 8 falsch ist, es sollte 7F sein. Da al¬ 
les andere korrekt ist, liegt der Fehler ziemlich sicher in der Tabelle. In der Tat, 
ist die Eintragung 8 in der Tabelle falsch. 

Das endgültige Programm ist: 


DEZIMAL IN SIEBEN-SEGMENT-UMWANDLUNG 



LDA 

#0 

;HOLE "BLANK"-CODE FÜR DIE ANZEIGE 


LDA 

$40 

.HOLE DATEN 


CPX 

#10 

.SIND DIE DATEN EINE DEZIMALZAHL? 


BCS 

DONE 

;NEIN. BEWAHRE FEHLER-CODE AUF 


LDA 

SSEG.X 

;HOLE SIEBEN-SEGMENT-CODE VON 
; TABELLE 

DONE 

STA 

$41 

;BEWAHRE SIEBEN-SEGMENT-CODE ODER 
: FEHLER-CODE AUF 

SSEG 

BYTE 

.BYTE 


$3F,$06,$5B,$4F,$66 

$6D,$7D.$07,$7F,$6F 
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Derartige in diesem Programm aufgetretene typische Fehler sollten von Pro¬ 
grammierern, die die Assemblersprache des 6502 verwenden, vermieden wer¬ 
den. Sie beinhalten: 

1) Vergessen der Initialisierung von Registern oder Speicherplätzen. 

2) Invertieren der Logik von bedingten Verzweigungen. 

3) Falsche Verzweigung im Gleichheitsfall der Operanden. 

4) Verwechslung unmittelbarer und direkter Adressierung, d.h. Daten und 
Adressen 

5) Vergessen, den momentanen Inhalt von Registern zu verfolgen. 

6) Verzweigung zur falschen Stelle, so daß ein bestimmter Weg durch das Pro¬ 
gramm falsch ist, 

7) Falsches Kopieren von Listen und Zahlen. 

8) Falsche Verwendung der indirekten Adressierung. 

Beachten Sie daß geradlinige Befehle (wie AND, DEC, INC) und einfache 
Adressier-Arten selten irgendwelche Probleme zur Folge haben. Unter speziell 
unangenehmen Fehlern, die häufig in der Assembler-Programmiersprache des 
6502 Vorkommen, ist die falsche Verwendung des Übertrags nach Subtraktio¬ 
nen oder Vergleichen (der Übertrag wird gesetzt, wenn kein "Borgen" erforder¬ 
lich ist) und Vergessen das Flag für die Dezimal-Betriebsart zu löschen. 
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Fehlersuch-Beispiel 2: Sortieren in absteigender Reihenfolge 

Das Programm sortiert eine Anordnung von Bi- FEHLERSUCHE IN 

närzahlen mit 8 Bits und ohne Vorzeichen in ab- EINEM SORTIER- 

steigender Reihenfolge. Die Anordnung beginnt PROGRAMM 

im Speicherplatz 0041 und seine Länge liegt im -— 

Speicherplatz 0040. 


Anfangsprogramm (vom Flußdiagramm in Bild 14-6): 



LDY 

#0 

.LÖSCHE AUSTAUSCH FLAG VOR DEM 




; DURCHLAUF 


LDX 

$40 

;HOLE LÄNGE DER ANORDNUNG 

PASS 

LDA 

$41,X 

iBEFINDET SICH DAS NÄCHSTE PAAR IN 




; RICHTIGER REIHENFOLGE? 


CMP 

$42,X 



BCC 

COUNT 

;JA. KEIN AUSTAUSCH ERFORDERLICH 


STA 

$42,X 

;NEIN, TAUSCHE PAAR AUS 

COUNT 

DEX 


;PRÜFE AUF VOLLSTÄNDIGEN DURCHLAUF 


BNE 

PASS 



DEY 


SIND ALLE ELEMENTE IN DER RICHTIGEN 




; REIHENFOLGE? 


BNE 

PASS 

;NEIN, MACHE EINEN WEITEREN DURCH- 




. LAUF 


BRK 




Die manuelle Überprüfung zeigt, daß alle Blöcke in dem Flußdiagramm im 
Programm ausgeführt wurden und daß alle Register initialisiert wurden. Die be¬ 
dingten Verzweigungen müssen sorgfältig geprüfl werden. Der Befehl BCC 
COUNT muß eine Verzweigung erzwingen, wenn der neue Wer: in A größer oder 
gleich dem nächsten Wert in der Anordnung ist. Erinnern Sie sich daran, daß wir 
Elemente in absteigender Reihenfolge sortieren und daß wir uns durch die An¬ 
ordnung auf die gebräuchliche Art und Weise des 6502 rückwärts bewegen 
Beachten Sie, daß der Gleichheitsfall nicht in einem Austausch resultieren darf, 
da dies eine endlose Schleife erzeugen würde, in der die beiden gleichen Ele¬ 
mente immer wieder ausgetauscht werden. 

Versuchen Sie ein Beispiel: 

(0041) - 30 
(0042) - 37 

CMP $42.X resultiert in der Berechnung von 30 - 37. Der Übertrag wird ge¬ 
löscht, da ein 'Borgen” erforderlich ist. Dieses Beispiel sollte in ei¬ 
nem Austausch resultieren, tut es jedoch nicht. 

BCS COUNT wird die richtige Verzweigung in diesem Fall liefern. Wenn die bei¬ 
den Zahlen gleich sind, wird der Vergleich den Übertrag setzen und BCS 
COUNT ist wieder richtig. 

Wie sieht es mit BNE PASS am Ende des Programmes aus? Wenn es irgend ein 
Element außerhalb der Reihenfolge gibt, wird das Austauschflag Eins sein, so 
daß die Verzweigung falsch ist. Sie sollte BEO PASS sein. 
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Nun versuchen Sie den ersten Durchlauf. Die Initialisierung sollte in folgendem 
resultieren: 


X = LÄNGE (2) 

V - 0 

Die Auswirkungen der Schleifen-Befehle sind: 


COUNT 


LDA 

$41,X 

;A = (0043) 

CMP 

$42,X 

,(0043) (0041) 

BCS 

COUNT 


STA 

$42,X 

;(0044)- (0043) 

DEX 


;X-LÄNGE- 1 (1) 

BNE 

PASS 


Die indizierten Adressen sind offensichtlich falsch, da sie beide hinter dem Ende 
der Anordnung liegen. Wir wollen sie ändern, indem wir zwei von den Adressen 
subtrahieren, die in den indizierten Befehlen enthalten sind. Diese Versetzung 
ist ein häufiges Problem in Assemblersprachen-Programmen des 6502, da 
Anordnungen mit fünf Elementen die Speicheradressen BASE bis BASE+4 bele¬ 
gen und nicht BASE+1 bis BASE+5. Wenn die indizierte Adressierung beim Mi¬ 
kroprozessor 6502 verwendet wird, so achten Sie sehr sorgfältig darauf. daS 
Ihre Adressen an einem oder anderen Ende der Anordnung nicht fehlerhaft sind. 
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Die Initialisierung ergibt nun die Werte: 


X - LÄNGE (2) 

< Y - 0 

Die Auswirkungen der Schleifenbefehle sind: 

LDA $3F,X ; A - (0041) 

CMP $40,X ;(0041)-(0042) 

BCS COUNT 

STA $40.X ;(0042) = (0041) 

COUNT DEX ;X - LANGE -1(1) 

BNE PASS 

Beachten Sie, daß wir bereits die bedingten Sprungbefehle geprüft haben. Of¬ 
fensichtlich ist die Logik falsch. Wenn die ersten beiden Elemente außerhalb der 
Reihenfolge liegen, so sollten die Resultate nach der ersten Wiederholung sein; 

(0041) - ALT (0042) 

(0042) - ALT (0041) 

X - LÄNGE-1 

Stattdessen sind sie: 

(0041) - UNVERÄNDERT 
(0042) - ALT (0041) 

X - LÄNGE-1 


Der Austausch erfordert etwas mehr Sorgfalt und die Verwendung des Stapels: 
PHA 

LDA $40,X 

STA $3F,X 

PLA 

STA $40 ( X 

Ein Austausch erordeil immer einen zeitweiligen Speicherplatz, in den eine 
Zahl gespeichert werden kann, während die andere transferiert wird 4 

Alle diese Änderungen erfordern ein neues Programm: 


LDY #0 ;LÖSCHE AUSTAUSCHFLAG VOR DEM 

; DURCHLAUF 

LDX $40 ;HOLE LÄNGE DER ANORDNUNG 

PASS LDA $3F,X ;IST DAS NÄCHSTE PAAR IN RICHTIGER 

; REIHENFOLGE? 

CMP $40,X 

BCS COUNT ;JA. KEIN AUSTAUSCH ERFORDERLICH 

PHA iNEIN, TAUSCHE ELEMENTE UNTER VER- 

; WENDUNG DES STAPELS AUS 

LDA $40.X 
STA $3F,X 
PLA 

STA $40,X 

COUNT DEX ;IST DURCHLAUF VOLLSTÄNDIG? 

BNE PASS 

OEY ;SIND ALLE ELEMENTE IN DER RICHTIGEN 

, REIHENFOLGE? 

BEO PASS ;NEIN, MACHE EINEN WEITEREN DURCH¬ 

LAUF 

BRK 
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Wie sieht es mit der letzten Wiederholung aus? Nehmen wir an, 
daß hier drei Elemente vorliegen. 

(0040) - 03 (Anzahl der Elemente) 

(0041) - 02 
(0042) - 04 
(0043) - 06 

Bei jedem Durchlauf inkrementiert das Programm X um 1. Daher ist bei Beginn 
der dritten Wiederholung (X) - 1. Die Auswirkung der Schleiten-Betehle sind: 

LDA $3F.X ;(A) ■= (0040) 

CMP $40.X ;(0040) - (0041) 

Dies ist nicht korrekt. Das Programm hat versucht, jenseits der Startadresse der 
Daten weiterzulauten. Die vorhergehende Wiederholung sollte in der Tat die 
etzte sein, da die Anzahl der Paare um 1 kleiner ist als die Anzahl der Elemen¬ 
te. Die Korrektur besteht im Reduzieren der Anzahl von Wiederholungen um 1; 
dies kann durch Plazieren von DEX nach LDX $40 geschehen. Wir müssen da¬ 
her 1 zu allen Adressen in den indizierten Befehlen addieren. 


Wie steht es mit den trivialen Fällen? Was geschieht, wenn die 
Anordnung überhaupt keine Elemente enthält, oder nur ein Element? Die Ant¬ 
wort lautet, daß das Programm nicht ordnungsgemäß arbeitet und einen gan¬ 
zen Datenbtock ohne irgendeine Warnung verfälschen kann (versuchen Sie 
es). Die Korrekturen zur Handhabung der trivialen Fälle sind einfach 
aber wesentlich. Sie kosten nur einige wenige Speicherplätze um Probleme zu 
vermeiden, die später schwer aufzufinden wären. Das neue Programm lautet: 


LDY #0 

LDX $40 
CPX #2 

BCC DONE 
DEX 

PASS LDA $40,X 

CMP $41,X 
BCS COUNT 
PHA 

LDA $41.X 
STA $40.X 
PLA 

STA $41.X 

COUNT DEX 

BNE PASS 
DEY 

BEQ PASS 
DONE BRK 


;LÖSCHE AUSTAUSCHFLAG VOR DEM 
; DURCHLAUF 

;HOLE LÄNGE DER ANORDNUNG 

;HAT DIE ANORDNUNG 2 ODER MEHR ELE- 

; MENTE? 

;NEIN, KEINE AKTION ERFORDERLICH 
ANZAHL DER PAARE-LÄNGE- 1 
;IST DAS NÄCHSTE PAAR IN RICHTIGER 
; REIHENFOLGE? 

;JA, KEIN AUSTAUSCH ERFORDERLICH 
;NEIN, TAUSCHE ELEMENTE UNTER VER- 
; WENDUNG DES STAPELS AUS 


;IST DER DURCHLAUF VOLLSTÄNDIG? 

;WAREN ALLE ELEMENTE IN RICHTIGER 
; REIHENFOLGE? 

.NEIN. MACHE EINEN WEITEREN DURCH- 
: LAUF 
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Nun ist es an der Zeit, das Programm auf einem Computer oder 
auf einem Simulator zu prüfen. Ein einfacher Datensatz wäre: 

(0040) = 02 Länge der Anordnung 
(0041) = 00 zu sortierende Anordnung 
(0042) = 01 

Dieser Satz besteht aus zwei Elementen in der falschen Reihenfolge. Das Pro¬ 
gramm sollte zwei Durchläufe ausführen. Der erste Durchlauf sollte die Elemen¬ 
te neu anordnen, wobei erzeugt wird: 

(0041) - 01 neu angeordnete Anordnung 

(0042) - 00 

Y - 01 Austausch Flag 

Der zweite Durchlaut sollte die Operation abschließen und erzeugen: 

Y = 00 Austausch-Flag 

Dieses Programm ist ziemlich lang, um es in Einzelschritten zu durchlaufen, so 
daß wir stattdessen Haltepunkte verwenden wollen. Jeder Haltepunkt wird den 
Computer anhalten und den Inhalt aller Register ausdrucken. Die Haltepunkte 
werden kommen: 

1) Nach DEX um die Anfangsbedingungen zu prüfen. 

2) NachCMP$41,X um den Vergleich zu prüfen. 

3) Nach STA $41.X um den Austausch zu prüfen, 

4) Nach DEY, um den Abschuß eines Durchlaufes durch die Anordnung zu 
prüfen. 

Der Inhalt der Register nach dem ersten Durchlauf wäre: 

Inhalt 
01 
00 

25 (35, wenn Sie BRKfürden Haltepunkt 
verwenden, da das BRK-Fiag gesetzt 
wird.) 

Diese sind alle korrekt, so daß das Programm die Anfangsbedingungen in die¬ 
sem Fall richtig berechnete. 
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Die Ergebnisse beim zweiten Haltepunkt wären: 


Inhalt 
00 
01 
00 

A4 (B4wenn Sie BRK verwenden) 

Diese Ergebnisse sind ebenfalls korrekt. 

Die Ergebnisse beim dritten Haltepunkt wären: 

Inhalt 
00 
01 

00 

26 (36 wenn Sie BRK verwenden) 

Ein Prüfen des Speichers zeigte: 

(0041) = 01 
(0042) = 00 

Die Ergebnisse beim vierten Haltepunkt wären: 

Inhalt 
00 
00 
FF 

A4 (B4 wenn Sie BRK verwenden) 

Hier ist das Nuit-Flag (Bit 1 des Status-Registers) nicht korrekt, das anzeigt, daß 
kein Austausch aufgetreten ist. Das Register Y enthält nicht den richtigen Wert 
- es sollte auf 1 nach dem Austausch gesetzt werden. In der Tat zeigt ein Blick 
auf das Programm, daß kein Befehl jemals das Indexregister Y änderte, um das 
Auftreten eines Austausches zu markieren. Die Korrektur besteht hier im Plazie¬ 
ren des Befehls LDY # 1 nach BCS COUNT. 

Nun besteht das Verfahren im Laden des Index-Registers Y mit dem korrekten 
Wert (Null), Setzen des Nuii-Fiags auf 1 und der Fortsetzung Die zweite Wieder¬ 
holung des zweiten Haltepunktes ergibt: 

Inhalt 
02 
00 
00 

25 (35 wenn Sie BRK verwenden) 
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Offensichtlich ist das Programm unkorrekt weitergelaufen, ohne die Register 
neu zu initialisieren (speziell das Indexregister X). Der bedingte Sprung, der vom 
Austausch-Fiag abhängt, sollte die Steuerung auf Jeden Fall zu einem Punkt des 
Programmes zurück transferieren, der X reininitialisiert. 

Beachten Sie, daß wir weder Y remintialisieren brauchen (es wird immer Null 
sein- weshalb?), noch die Länge der Anordnung neuerlich prüfen müssen. 


EINFÜHRUNG IN DAS TESTEN 


Das Testen des Programms hängt eng mit der 
Fehlersuche im Programm zusammen. Sicher 
werden einige der Testfälle gleich sein wie die 
Testdaten, die für die Fehlersuche verwendet 
werden, wie etwa: 


VERWENDUNG VON 
TESTFÄLLEN BEI 
DER FEHLERSUCHE 


Die endgültige Version des Programmes ist: 


SORT 

LDY 

#0 

;LÖSCHE AUSTAUSCHFLAG ZU BEGINN 

LDX 

$40 

;G1BT ES ZWEI ODER MEHR ELEMENTE? 


CPX 

#2 

;NEIN, KEINE AKTION NÖTIG 


BCC 

DONE 

ITER 

LDX 

$40 

;JA, ANZAHL DER PAARE» LANGE - 1 


DEX 



PASS 

LDA 

$40,X 

;IST DAS NÄCHSTE PAAR IN RICHTIGER 


; REIHENFOLGE? 


CMP 

$41,X 



BCS 

COUNT 

;JA, KEIN AUSTAUSCH ERFORDERLICH 


LDY 

#1 

;NEIN. SEZTE AUSTAUSCH-FLAG 


PHA 

JAUSCHE ELEMENTE UNTER 




: VERWENDUNG DES STAPELS AUS 


LDA 

$ 41, X 



STA 

$40,X 



PLA 




STA 

$41,X 


COUNT 

DEX 


;IST DER DURCHLAUFANGESCHLOSSEN? 


BNE 

DEY 

PASS 

;WAREN ALLE ELEMENTE IN DER 



; RICHTIGEN REIHENFOLGE? 


BEO 

ITER 

;NEIN, MACHE EINEN WEITEREN DURCH- 



; LAUF 

DONE 

BRK 




Offensichtlich können wir nicht alle möglichen Eingangswerte für dieses Pro¬ 
gramm prüfen. Zwei weitere einfache Datensätze für Fehlersuch-Zwecke sind: 

1) Zwei gleiche Elemente 

(0040) - 02 
(0041) - 00 
(0042) - 00 

2) Zwei Elemente, bereits in absteigender Reihenfolge 

(0040) - 02 
(0041) - 01 
(0042) - 00 


• T ri viale Fälle, wie keine Daten oder ein einziges Element. 

• Spezielle Fälle, die das Programm aus irgendwelchen Gründen auswählt. 

• Einfache Beispiele, die spezielle Teile des Programmes überprüfen. 

Im Falle des Umwandlungsprogrammes dezimal in Sieben-Segment, umfassen 
diese Fälle alle möglichen Situationen. Die Testdaten bestehen aus: 

• Die Zahlen 0 bis 9. 

• DerGrenzfall 10 

• Der willkürliche Fall 6B. 

Das Programm unterscheidet keine weiteren Fälle. Hier sind Fehlersuche und 
Testen effektiv das gleiche. 

Bei dem Sortierprogramm ist die Aufgabe schwieriger. Die Anzahl der Elemen¬ 
te könnte von 0 bis 255 reichen, und jedes der Elemente könnte irgendwo in die¬ 
sem Bereich liegen. Die Zahl der möglichen Fälle ist daher außerordentlich 
groß. Ferner ist das Programm einigermaßen komplex. Wie sollen wir Testdaten 
auswählen, die uns einen gewissen Grad von Vertrauen zu diesem Programm 
geben? Hier erfordert das Testen einige grundlegende Entscheidungen. Das 
Testproblem ist bes onders schwierig, wenn das Programm von einer Folge von 
Echtzeit-Daten abhängt. Wie wählen wir die Daten, erzeugen diese und führen 
sie dem Mikrocomputer in realistischer Weise zu? 

Die meisten der früher erwähnten Hilfsmittel für die Feh¬ 
lersuche sind auch beim Testen sehr nützlich. Logik- oder 
Mikroprozessor-Analysatoren können beim Überprüfen 
der Hardware helfen, Simulatoren beim Prüfen der Soft¬ 
ware. Andere Hilfsmittel können ebenfalls nützlich sein, 
zum Beispiel: 

1) E/A-Simulationen, die eine Vielzahl von Bausteinen von einem einzelnen 
Eingang und einem einzelnen Ausgangs-Baustein simulieren können. 

2) 'Tn-Circuir-Emulatoren gestatten Ihnen das Anschließen des Prototyps an 
ein Entwicklungssystem oder Steuerpult und das Testen. 

3) ROM-Simulatoren, die die Flexibilität eines RAMs besitzen, jedoch auch die 
zeitliche Steuerung des speziellen ROMs und PROMs, die im endgültigen Sy¬ 
stem verwendet werden. 

4) Echtzeit-Betriebssysteme, die Eingaben oder Unterbrechungen zu speziel¬ 
len Zeiten (oder vielleicht willkürlich) liefern und das Auftreten von Ausgaben 
markieren. Echtzeit-Haltepunkte und "Tracer" (Ablaufverfolger) können 
ebenso enthalten sein. 

5) Emulationen (häufig auf mikroprogrammierbaren Computern), die eine Echt¬ 
zeit-Ausführungsgeschwindigkeit und programmierbare E/A ergeben.* 

6) Interfaces, die einem anderen Computer die Steuerung des E/A-Systems 
und das Testen des Mikrocomputer-Programmes gestatten. 


TEST¬ 

HILFEN 
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7) Testprogramme, die jede Verzweigung in einem Programm auf logische Feh- 

8) Testprogramme, die willkürlich Daten oder andere Verteilungen erzeugen 
können. 

Es gibt formelle Test-Theorien, aber sie sind gewöhnlich nur für sehr kurze Pro¬ 
gramme verwendbar. 

Man muß sehr sorgfältig darauf achten, daß die Testgeräte den Test selbst 
nicht verfälschen, indem sie die Umgebungsbedingungen verändern. Häufig 
können Testgeräte Eingangs- und Ausgangssignale puffern, Zwischenspei¬ 
chern oder verändern. Das tatsächliche System könnte dies nicht ausführen, 
und könnte sich daher etwas anders verhalten. Ferner kann zusätzliche Soft¬ 
ware in dem Test-Auf bau einen Teil des Speicherraumes oder Teil des Unter- 
brechungssystemes verwenden. Es kann auch eine Fehler-Korrektur und an¬ 
dere Eigenschaften besitzen, die Im endgültigen System nicht vorhanden sind. 
Ein Software-Test muß ebenso realistisch sein wie ein Hardware-Test, da Soft¬ 
ware-Fehler ebenso kritisch wie Hardware-Fehler sein können. 

Emulationen und Simulationen sind natürlich niemals völlig genau. Sie sind ge¬ 
wöhnlich ausreichen für das Prüfen der Logik, können jedoch selten helfen, 
das Interface oder die zeitliche Steuerung zu testen. Andererseits ergeben 
Echtzeit-Testgeräte keinen Überblick über die Programmlogik und können das 
Interfacing und die zeitliche Steuerung beeinflussen. 


AUSWAHL VON TESTDATEN 

Sehr wenige reale Programme können für sämtliche möglichen Fälle überprüft 
werden. Der Entwickler muß einen Satz von Beispielen wählen, die auf irgend¬ 
eine Weise den gesamten Bereich der Möglichkeiten umfassen. 


Testen sollte natürlich ein Teil des gesamten Ent- 
wicklungs Vorganges sein. Entwicklung mit 
schrittweiser Verfeinerung (Top-down Design) 
und strukturierte Programmierung beinhalten be¬ 
reits das Testen als einen Teil der Entwicklung. 

Dies wird strukturiertes Testen genannt. 6 Jedes Modul innerhalb eines struktu- 
nerten Programmes sollte seperat geprüft werden. Testen sollte ebenso wie 
das Cod'teren modular, strukturiert und "Top-down” sein. 


Aber das läßt noch immer die Frage für die Aus¬ 
wahl von Testdaten für ein Modul offen. Der Ent¬ 
wickler muß zuerst alle speziellen Fälle erfas¬ 
sen, die ein Programm erkennt. Diese können 
enthalten: 

• Triviale Fälle 

• Gleichheits-Fälle 

• Spezielle Situationen 

Die Testdaten sollten alle diese Fälle umfassen. 


Als nächstes müssen Sie jede Klasse von Daten 
festlegen, die Anweisungen innerhalb des Pro¬ 
grammes unterscheiden können. Diese können 
enthalten: 

• Positive oder negative Zahlen 

• Zahlen oberhalb oder unterhalb einer bestimmten Schwelle 

• Daten, die spezielle Sequenzen oder Zeichen enthalten, oderauch nicht. 

• Daten, die zu einem bestimmten Zeitpunkt nicht vorliegen. 

Wenn die Module kurz sind, sollte die Gesamtzahl der Klassen noch klein sein, 
obwohl jede Unterteilung multiplikativ ist, das heißt, zwei Zwei-Weg-Unter- 
teilungen ergeben vier Datenklassen. 


Sie müssen nun die Klassen entsprechend auf¬ 
teilen, ob das Programm ein unterschiedliches 
Resultat für jede Eingabe in der Klasse (wie in 
einer Tabelle) erzeugt oder das gleiche Resultat 
für jede Eingabe (wie etwa das Warnen, daß ein Parameter sich oberhalb einer 
Schwelle befindet) ergibt, in einem bestimmten Fall kann man jedes Element 
einschließen, wenn die Gesamtzahl klein ist oder nur ein Beispiel, wenn die Zatil 
groß ist. Das Beispiel sollte alle Grenzfälle beinhalten und wenigstens einen will¬ 
kürlich gewählten Falt. Tabellen für Zufallszahlen sind aus Büchern zu entneh¬ 
men und Generatoren für Zufallszahlen Sind Teil der meisten Computer. 

Sie müssen sehr sorgfältig Unterscheidungen beobachten, die nicht offen¬ 
sichtlich sein können. Beispielsweise wird der 6502 eine 8-Bit-Zahl ohne Vor¬ 
zeichen größer als 127 als negativ ansehen. Sie müssen dies in Betracht zieh¬ 
en, wenn Sie die Sprungbefehle, die von Vorzeichenbit abhäncgen, verwenden. 
Sie müssen auch auf Befehle achten, die die Flags und den Überlauf bei der 
Arithmetik mit Vorzeichen nicht beeinflussen, sowie zwischen Größen für die 
Adressenlänge (16-Bit) und Größen für Datenlängen (8-Bit) unterscheiden. 


AUSWAHL DER 
DATEN VON DEN 
KLASSEN 


BILDEN VON 
DATEN-KLASSEN 


TESTEN 

SPEZIELLER FÄLLE 


STRUKTURIERTES 

TESTEN 
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Testbeispiel 1: Sortierprogramm 

Die speziellen Fälle sind hier offensichtlich: 

• Keine Elemente in der Anordnung 

• Ein Element, dessen Größe willkürlich gewählt werden kann. 


TESTEN EINES 
SORTIERPROGRAMMS 


Der andere spezielle, zu berücksichtigende Fall liegt vor, wenn die Elemente 
gleich sind. 


Es kann hier einige Probleme mit Vorzeichen und Datenlängen geben. Beachten 
Sie. daß die Anordnung selbst weniger als 256 Elemente enthalten muß. Die 
Verwendung des Befehls LDY #1 anstatt INY zum Setzen des Austausch-Flags 
bedeutet, daß es keine Schwierigkeit geben wird, wenn die Anzahl der Elemente 
oder Austausch-Vorgänge 128 überschreitet. Wir könnten den Einfluß des Vor¬ 
zeichens prüfen, indem wir für die Hälfte der Testfälle die Anzahl der Elemente 
zwischen 128 und 255 nehmen und eine andere Hälfte zwischen 2 und 127. Alle 
Größen sollten willkürlich gewählt werden, um die Prüfung möglichst vorurteils¬ 
frei auszuführen. 


Testbeispiel 2: Selbstprüfende Zahlen (siehe Kapitel 8) 


Hier wollen wir voraussetzen, daß eine vorherge¬ 
hende Gültigkeitsprüfung gesichert hat, daß die 
Zahl die richtige Länge besitzt und aus gültigen 
Ziffern besteht Da das Programm keine weiteren 
Unterscheidungen macht, sollten die Testdaten willkürlich gewählt werden. Hier 
ist eine Tabelle mit Zufallszahlen oder ein Zufallszahlen-Generator ideal Der 
Bereich der Zufallszahlen liegt zwischen 0 und 9. 


TESTEN EINES 

ARITHMETISCHEN 

PROGRAMMS 


VORSICHTSMASSNAHMEN BEIM TESTEN 

Der Entwickler kann die Stufe des Testens vereinfachen, 

indem er die Programme entsprechend entwickelt. Sie 

sollten folgende Regeln beachten: 

1) Versuchen Sie, triviale Fälle so früh wie möglich zu elimi¬ 
nieren, ohne unnotwendige Unterscheidungen einzu¬ 
führen. 

2) Versuchen Sie, die Anzahl der speziellen Fälle auf ein Minimum zu redu¬ 
zieren. Jeder spezielle Fall bedeutet zusätzliches Testen und Zeit für die 
Fehlersuche. 

3) Überlegen Sie die Ausführung von Gültigkeits- oder Fehlerprütung an den 
Daten vor deren Verarbeitung. 

4) Achten Sie sorgfältig auf unbeabsichtigte oder unnötige Unterscheidungen, 
speziell bei der Handhabung von Zahlen mit Vorzeichen oder bei der Ver¬ 
wendung von Operationen, die sich auf Zahlen mit Vorzeichen beziehen. 

5) Prüfen Sie Grenzfälle manuell. Sie sind sehr häufig eine Fehlerquelle. Verge¬ 
wissern Sie sich, daß die Aufgaben-Definition spezifiziert, was in diesen Fäl¬ 
len zu geschehen hat. 

6) Machen Sie das Programm soweit als möglich allgemein gültig Jede Unter¬ 
scheidung und seperate Routine erhöht die Anforderung an das Testen. 

7) Unterteilen Sie das Programm und entwickeln Sie die Module so, daß das Te¬ 
sten in Schritten erfolgen kann, in Verbindung mit den anderen Stufen der 
Software- Entwicklung. 


REGELN FÜR 
DASTESTEN 


SCHLUSSFOLGERUNGEN 

Fehlersuche und Testen sind die Stiefkinder des Software-Entwicklungs¬ 
vorganges. Die meisten Projekte lassen für sie viel zu wenig Zeit und 
die meisten Bücher vernachlässigen sie. Jedoch Entwickler und Manager fin¬ 
den häufig, daß diese Stufen die aufwendigsten und zeitraubendsten sind. Der 
Fortschritt ist sehr schwierig zu messen und zu erzielen. Fehlersuche und 
Testen bei Mikroprozessor-Software ist verhältnismäßig schwierig, da die lei¬ 
stungsfähigen Hardware- und Software-Hilfsmittel, die auf größeren Compu¬ 
tern verwendet werden können, selten für Mikrocomputer verfügbar sind. 

Der Entwickler sollte Fehlersuche und Testen sorgfältig planen. Wir empfehlen 
folgendes Vorgehen: 

1) Versuchen Sie Programme zu schreiben, die leicht zu testen und fehlerfrei 
zu machen sind. Modulare Programmierung, strukturiere Programmierung 
und Entwicklung mit stufenweiser Verfeinerung sind sehr nützliche 
Techniken. 

2) Bereiten Sie einen Fehlersuch- und Testplan als Teil der Programm-Ent¬ 
wicklung vor. Entscheiden Sie früh genug, welche Daten Sie erzeugen müs¬ 
sen und welche Geräte Sie benötigen. 

3) Testen und machen sie jedes Modul fehlerfrei, als Teil der Entwicklung mit 
schr ittweiser Verfeinerung. 

4) Machen Sie die Logik jedes Moduls systematisch fehlerfrei. Verwenden Sie 
Prüflisten, Haltepunkte und das Einzelschritt-Verfahren. Wenn die Pro¬ 
grammlogik komplex ist, überlegen Sie die Verwenudng des Software- 
Simulators. 

5) Prüfen Sie die zeitliche Steuerung jedes Moduls systematisch, wenn dies 
ein Problem darstellt. Ein Ozillograf kann zahlreiche Probleme lösen, wenn 
Sie den Test entsprechend vorsehen. Ist die zeitliche Steuerung sehr kom¬ 
plex, überlegen Sie die Verwendung eines Logik- oder Mikroprozessor- 
Analysators. 

6) Vergewissern Sie sich, daß die Testdaten auch repräsentative Beispiele 
sind. Achten Sie auf alle Klassen von Daten, die das Programm unterschei¬ 
den kann. Schließen Sie alle speziellen und trivialen Fälle ein. 

7) Wenn das Programm jedes Element anders behandelt, oder die Anzahl der 
Fälle groß ist, wählen Sie die Testdaten willkürlich aus. 7 

8) Zeichnen Sie alle Testergebnisse als Teil der Dokumentation auf. Wenn 
Probleme auftreten, so brauchen Sie nicht die Testfälle zu wiederholen, 
die Sie bereits ausgeführt haben. 
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Kapitel 15 

DOKUMENTATION UND 
NEU-ENTWICKLUNG 


Das tatsächlich funktionierende Programm ist nicht die einzige Anforderung 
an die Software-Entwicklung. Die entsprechende Dokumentation stellt ebenso 
einen wichtigen Teil der Software dar. Die Dokumentation hilft nicht nur dem 
Entwickler beim Testen und bei der Fehlersuche, sondern ist auch für späteren 
Gebrauch und Erweiterung des Programmes sehr wesentlich. Ein schlecht do¬ 
kumentiertes Programm wird schwierig zu warten, neuerlich zu verwenden 
oder zu erweitern sein. 

Gelegentlich verwendet die erste Version eines Programms zuviel Speicher 
oder wird zu langsam ausgeführt. Der Entwickler muß dann Wege überlegen, 
um dieses Programm zu verbessern. Diese Stufe wird Neu-Entwicklung ge¬ 
nannt und erfordert, daß Sie sich auf jene Teile des Programms konzentrieren, 
bei denen eine Verbesserung den größten Erfolg verspricht. 


SELBST-DOKUMENTIERENDE PROGRAMME 


Obwohl kein Programm jemals selbständig do- REGELN FÜR SELBST- 
kumentierend ist, können einige der früher er- DOKUMENTIERENDE 
wähnten Regeln sehr nützlich sein. Diese bein- PROGRAMME 
halten: - 

- Klare einfache Struktur mit so wenig Steuerungstransfers (Sprüngen) wie 
möglich. 

- Verwendung sinnvoller Namen und Markierungen. 

- Verwendung von Namen für E/A-Bausteine, Parameter, numerische Faktoren 
etc. 

- Es sollte besonderer Wert auf Einfachheit anstatt auf geringere Ersparnisse 
bei der Verwendung des Speichers, Ausführungszeit etc. gelegt werden. 

Beispielsweise sendet das folgende Programm eine Reihe von Zeichen zu einem 
Fernschreiber. 

LDX $40 

W LDA S0FFF.X 

STA $A000 
JSR XXX 

DEX 

BNE W 

BRK 
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Sogar ohne Kommentare können wir dieses Programm wie folgt verbessern: 


MESSG 

-$1000 


COUNT 

=$40 


TTYVIA 

WVOOO 



LDX 

COUNT 

OUTCH 

LDA 

MESSG-1.X 


STA 

TTYVIA 


JSR 

DEX 

BITDLY 


BNE 

BRK 

OUTCH 


Sicher ist dieses Programm leichter zu verstehen als die frühere Version. Auch 
ohne weitere Dokumentation können Sie wahrscheinlich die Arbeitsweise des 
Programms begreifen sowie die Bedeutung der meisten Variablen erkennen. 

Andere Dokumentationsverfahren können die Selbst-Dokumentation nicht er¬ 
setzen. 


Einige weitere Anmerkungen bezüglich der Auswahl von AUSWAHL 

Namen: NÜTZLICHER 

NAMEN _ 

1 ) Verwenden Sie sinnvolle Namen, wenn diese verfügbar 
sind, wie TTV oder CRT für Ausgangsgeräte. START 
oder RESET für Adressen. DELAY oder SORT für Unter¬ 
programme, COUNT oder LENGTH für Daten. 

2) Vermeiden Sie Abkürzungen wie S 16BA tür SORT 16 BIT ARRAY. Dies wird 
selten etwas für den Anwender bedeuten. 

3) Verwenden Sie volle Worte oder möglichst nahezu vollkommene Worte 
wenn möglich, wie DONE. PRINT, SEND etc. 

4) Halten Sie die Namen so charakteristisch wie möglich. 
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KOMMENTARE 


Die offensichtlichste Form zusätzlicher Dokumentation ist der Kommentar. Je¬ 
doch sehr wenige Programme (einschließlich der meisten in Büchern) besitzen 
wirklich effektive Kommentare. Sie sollten die folgenden Richtlinien 
für gute Kommentare beachten: 


1) Wiederholen Sie nicht die Bedeutung des Befehlsco- RICHTLINIEN 

des. Erklären Sie eher den Zweck des Befehls im FÜR 
Programm. Kommentare wie KOMMENTARE 

DEX ;X=X—1 

tragen überhaupt nichts zur Dokumentation bei. Verwenden Sie stattdessen 

DEX ;ZEILENZAHL-ZEILENZAHL-1 

Erinnern Sie sich daran, daß Sie ja bereits wissen, was der Operationscode 
bedeutet und diese jeder in einem Handbuch nachschlagen kann. Es ist viel 
wichtiger zu erklären, weiche Aufgabe das Programm austührt. 

2) Machen Sie die Kommentare so deutlich wie möglich. Verwenden Sie keine 
Abkürzungen oder Akronyme, außer sie sind allgemein bekannt (wie ASCII, 
VIA oder UART) oder Standard (wie Nr. für Nummer, ms für Millisekunden, 
etc.). Vermeiden Sie Kommentare wie 

DEX ;LN - LN-1 

oder 

DEX ;DEC LN UM 1 

Die wenigen zusätzlichen Eingaben stellen keinen nennenswerten Aufwand 
dar. 

3) Kommentieren Sie jeden wichtigen oder nicht sehr offensichtlichen Punkt. 

Seien Sie sorgfältig beim Markieren von Operationen, die keine offensichtli¬ 
che Funktion besitzen, wie etwa 

AND #%001 00000 ;TAPE READER-BIT AUS 

oder 

LDA GCODL.X ;UMWANDLUNG IN GRAY-CODE MIT 
; TABELLE 

Offensichtlich erfordern E/A-Operationen häufig ausführliche Kommentare. 
Wenn Sie sich nicht ganz sicher darüber sind, was ein Befehl ausführt, oder 
Sie darüber nachdenken müssen, fügen Sie einen erklärenden Kommentar 
hinzu. Der Kommentar wird Ihnen später viel Zeit ersparen und nützlich bei 
der Dokumentation sein. 
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4) Kommentieren Sie keine offensichtlichen Dinge. Ein Kommentar aut jeder 
Zeile macht es schwierig, die wichtigen Punkte aufzufinden. Standard- 
Sequenzen wie 


BNE SEARCH 

müssen nicht markiert werden, außer Sie führen irgend etwas Spezielles 
aus. Ein Kommentar wird häufig für mehrere Zeilen ausreichen wie in 

LSR A ;HOLE DIE HÖCHSTWERTIGE STELLE 

LSR A 

LSR A 

LSR A 

LSR A 

LDA $40 TAUSCHE HÖCHSTWERTIGE UND 

LDA $41 ; NIEDRIGSTWERTIGE BYTES AUS 

STA $41 

STX $40 

5) Plazieren Sie Kommentare auf die Zeilen, auf die sie sich beziehen, oder 
auf den Beginn einer Sequenz. 

6) Halten Sie Ihre Kommentare immer auf dem neuesten Stand. Wenn Sie ein 
Programm ändern, ändern Sie auch die Kommentare. 

7) Verwenden Sie Standardformen und Ausdrücke beim Kommentieren. 
Stoßen Sie sich nicht an Wiederholungen. Unterschiedliche Namen für die 
gleichen Dinge sind verwirrend. Auch wenn die Variationen etwa COUNT 
und COUNTER, START und BEGINN, DISPLAY und LEDS oder PANEL und 
SWITCHES sind 

Es bringt auf jeden Fall Gewinn, wenn man konsequent ist. Die Variationen 
können im Augenblick offensichtlich sein, jedoch später nicht mehr so klar 
erscheinen. Andere werden Sie von Anfang an verwirren. 

8) Halten Sie d'te Kommentare kurz. Überfassen Sie eine vollständige Be¬ 
schreibung der Dokumentation. Andernfalls kann das Programm in den 
Kommentaren untergehen, und Sie werden Mühe haben, es zu finden. 

9) Verbessern Sie ständig Ihre Kommentare. Wenn Sie einen Kommentar 
nicht lesen oder verstehen können, nehmen Sie sich die Zeit, es zu ändern. 
Wenn Sie merken, daß die Auflistung verwirrend wird, fügen Sie einige leere 
Zeilen hinzu. Die Kommentare werden sich nicht selbst verbessern. In der 
Tat werden sie schwierig, wenn Sie eine Aufgabe erledigt haben und ver¬ 
gessen, was das Programm genau ausgeführt hat. 

10) Vor jedem größeren Abschnitt, Unterabschnitt oder Unterprogramm set¬ 
zen Sie eine Anzahl von Kommentaren ein, die die Funktionen des folgen¬ 
den Codes beschreiben. Besonders sorgfältig sollten alle Eingaben. Ausga¬ 
ben und Nebeneffekte beschrieben werden, sowie die verwendeten Algo¬ 
rithmen. 

11) Es bewährt sich immer, wenn beim Modifizieren von Programmen Kom¬ 
mentare angebracht werden, die das Datum, den Autor und die Art der 
ausgeführten Modifikation aufzeigen. 

Erinnern Sie sich daran, daß Kommentare wichtig sind. Gute Kommentare 

werden Ihnen Zeit und Mühe sparen. Investieren Sie einige Zeit in die Kom¬ 
mentare und versuchen Sie, diese so effektiv wie möglich zu machen. 
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KOMMENTIER-BEISPIEL 1: ADDITION MIT MEHRFACHER 

GENAUIGKEIT 


Das grundlegende Programm lautet: 

LDX $40 

CLC 

ADDWD LDA $40 X 
ADC $50.X 

STA $40,X 

DEX 

BNE ADDW 

BRK 

Kommentieren Sie zuerst die wichtigen Punkte. Diese sind typisch die Initialisie¬ 
rungen, das Holen von Daten und die Verarbeitungs-Operationen. Befassen Sie 
sich nicht mit Standard-Sequenzen, wie das Weiterstellen von Zeigern und Zäh¬ 
lern. Erinnern Sie sich daran, daß Namen deutlicher als Zahlen sind, und ver¬ 
wenden Sie daher diese weitgehend 

Die neue Version des Programms lautet: 


ADDITION MIT MEHRFACHER GENAUIGKEIT 



;DIESES PROGRAMM FÜHRT EINE BINÄRE MEHRBYTE-ADDITION AUS 


EINGABEN: SPEICHERPLATZ 0040(HEX)= LÄNGE DER ZAHLEN (IN BYTES) 
SPEICHERPLÄTZE 0041 BIS 0050 (HEX) = ERSTE ZAHL 
BEGINNEND MIT MSB'S 

SPEICHERPLÄTZE 0051 BIS 0060 (HEX)=ZWEITE ZAHL 
BEGINNEND MIT MSB'S 


AUSGABEN: SPEICHERPLÄTZE 0041 BIS 0050 (HEX)= SUMME BEGINNEND 
MIT MSB’S 


LENGTH 

-$40 


NUMB1 

-$41 


NUMB2 

-$y 



LDX 

LENGTH 


CLC 


ADDWD 

LDA 

NUMB1-1.X 


ADC 

NUMB2-1.X 


STA 

NUMB1-1.X 


DEX 


BNE 

ADDWD 


BRK 



;ZÄHLUNG - LÄNGE DER ZAHLEN (IN 
; BYTES) 

;HOLE BYTE VON REIHE 1 
;ADDIERE BYTE VON REIHE 2 
iSPEICHERE ERGEBNIS IN REIHE 1 

;SETZE FORT BIS ALLE BYTES ADDIERT 
; SIND 
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Als zweites sehen Sie sich jeden Befehl an, der keine offensichtliche Funktion 
haben könnte und markieren Sie diese, Hier ist der Zweck von CLC das Lö¬ 
schen des Übertrags beim ersten Durchlauf. 

Drittens fragen Sie sich selbst, ob die Kommenta- FRAGEN BEI DER 

re Ihnen das sagen, was Sie bei der Verwendung KOMMENTIERUNG 

des Programms wissen wollen, zum Beispiel: 

1) Wo wird in das Programm eingetreten? Gibt es alternative Eintritts-Punkte? 

2) Welche Parameter sind erforderlich? Wie und in welcher Form müssen sie 
geliefert werden? 

3) Welche Operationen führen das Programm aus? 

4) Von wo werden die Daten geholt? 

5) Wo werden die Ergebnisse gespeichert? 

6) Welche speziellen Fälle werden berücksichtigt? 

7) Was macht das Programm bei Fehlern? 

8) Wie wird aus dem Programm ausgetreten? 

Einige der Fragen können vielleicht für ein spezielles Programm nicht relevant 
sein und einige der Antworten vielleicht offensichtlich. Vergewissern Sie sich, 
daß Sie sich nicht extra hinsetzen und das Programm zerlegen müssen um 
herauszufinden, wie die Antworten lauten Erinnern Sie sich daran, daß zuviel 
Erklärung unnötiger Ballast ist, den Sie erst wieder beseitigen müssen. Gibt es 
irgend etwas, was Sie zu dieser Liste hinzufügen oder entfernen würden? Wenn 
ja, führen Sie es aus - Sie sind dann jemand, der ein Gefühl dafür hat, daß das 
Kommentieren ausreichend und vernünftig ist 


ADDITION MIT MEHRFACHER GENAUIGKEIT 


DIESES PROGRAMM FÜHRT EINE BINÄRE MEHRBYTE-ADDITION AUS 

EINGABEN: SPEICHERPLATZ 0040 (HEX)= LÄNGE DER ZAHLEN (IN 
BYTES) 

SPEICHERPLÄTZE 0041 BIS 0050 (HEX) - ERSTE ZAHL 
BEGINNEND MIT MSB'S 

SPEICHERPLÄTZE 0051 BIS 0060 (HEX) - ZWEITE ZAHL 
BEGINNEND MIT MSB'S 

AUSGABEN: SPEICHERPLÄTZE 0041 BIS 0050 (HEX) = SUMME BEGINNEND 


LENGTH 

=$40 

MIT MSB'S 

LÄNGE DER ZAHLEN (IN BYTES) 

NUMB1 

*$41 


MSB'S DER ERSTEN ZAHL UND ERGEBNIS 

NUMB2 

*$51 


MSB'S DER ZWEITEN ZAHL 


LDX 

LENGTH 

ZÄHLUNG - LÄNGE DER ZAHLEN (IN 

ADDWD 

CLC 

LDA 

NUMB1-1.X 

BYTES) 

LÖSCHE ÜBERTRAG ZU BEGINN 

HOLE BYTE VON REIHE 1 


ADC 

NUMB2-1 ,X 

ADDIERE BYTE VON REIHE 2 


STA 

NUMB1-1 ,X 

SPEICHERE ERGEBNIS IN REIHE 1 


DEX 

BNE 

ADDWD 

SETZE FORT BIS ALLE BYTES ADDIERT 


BRK 


SIND 
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Kommentier-Beispiel 2: Fernschreiber-Ausgabe 

Das grundlegende Programm lautet: 


LDA 

$60 

ASL 

A 

LDX 

#11 

STA 

$A000 

JSR 

BITDLY 

ROR 

A 

SEC 


DEX 


BNE 

TBIT 

BRK 



Das Kommentieren der wichtigsten Punkte und Hinzufügen von Namen ergibt: 


;FERNSCHREIBER-AUSGABE 

;DIESES PROGRAMM DRUCKT DEN INHALT DER SPEICHERPLÄTZE 0060 
, (HEX) ZUM FERNSCHREIBER 


EINGABEN: ZU SENDENDE ZEICHEN IM SPEICHERPLATZ 0060 
AUSGABEN: KEINE 


NBITS 

-11 


ANZAHL DER BITS JE ZEICHEN 

TDATA 

-$60 


ADRESSE DES ZU SENDENDEN ZEICHENS 

TTYVIA 

-$A000 


FERNSCHREIBERAUSGANGS-DATENPORT 


LDA 

$60 

HOLE DATEN 


ASL 

A 

VERSCHIEBE NACH LINKS UND BILDE 
STARTBIT 


LDX 

# NBITS 

ZÄHLUNG-ANZAHL DER BITS IN ZEICHEN 

TBIT 

STA 

TTYVIA 

SENDE NÄCHSTES BIT ZUM 
FERNSCHREIBER 


JSR 

BITDLY 

WARTE 1 BITZEIT 


ROR 

SEC 

DEX 

A 

HOLE NÄCHSTES BIT 

SETZE ÜBERTRAG ZUM BILDEN DER 
STOPBITS 


BNE 

BRK 

TBIT 

ZÄHLE BITS 
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Beachten Sie, wie leicht wir dieses Programm ändern könnten, so daß es eine 
ganze Reihe von Daten transferieren würde, beginnend bei der Adresse in den 
Speicherplätzen DPTR und DPTR+1 und endend mit einem ’'03’'- (ASCII ETX) 
Zeichen. Ferner wollen wir das Terminal zu einem Gerät mit 30 cps und mit 
einem Stopbit machen (wir werden das Unterprogramm BITDLY zu ändern 
haben). Versuchen Sie die Änderungen auszuführen, bevor Sie sich nachste¬ 
hende Auflistung ansehen: 


AUSGABEPROGRAMM FÜR EINE ZEICHENREIHE 

DIESES PROGRAMM SENDET EINE REIHE VON ZEICHEN ZU EINEM 
TERMINAL MIT 30 CPS, ÜBERTRAGUNG WIRD BEENDET, WENN EIN 
ASCII-ZEICHEN ETX (03 HEX) FESTGESTELLT WIRD 

EINGABEN: SPEICHERPLÄTZE 0060 UND 0061 (HEX) ENTHALTEN 
ADRESSE DER ZU SENDENDEN REIHE 
AUSGABEN: KEINE 


DPTR 

=$60 


ZEIGER ZUM AUSGANGS-DATENPUFFER 

ENDCH 

=$03 


ABSCHLUSSZEICHEN-ASCII ETX 

NBITS 

-10 


ANZAHL DER BITS PRO ZEICHEN 

TRMVIA 

=$A000 


AUSGANGS-DATENPORT DESTERMINALS 


LDY 

#0 

ZEIGE ZUM BEGINN DES AUSGANGS¬ 




DATENPUFFERS 

TCHAR 

LDA 

(DPTR),Y 

HOLE EIN ZEICHEN VOM PUFFER 


CMP 

#ENDCH 

IST ES EIN ABSCHLUSSZEICHEN? 


BEQ 

DONE; JA.DONE 


ASL 

A 

NEIN, VERSCHIEBE NACH LINKS UND 




BILDE STARTBIT 


LDX 

NBITS 

ZÄHLUNG = ANZAHL DER BITS JE ZEICHEN 

TBIT 

STA 

TRMVIA 

SENDE NÄCHSTES BIT ZUM TERMINAL 


JSR 

BITDLY 

WARTE 1 BITZEIT 


ROR 

A 

HOLE NÄCHSTES BIT 


SEC 


SETZE ÜBERTRAG ZUM BILDEN DES 




STOPBITS 


DEX 




BNE 

TBIT 

ZÄHLE BITS 


INY 

;GEHE ZUM NÄCHSTEN ZEICHEN WEITER 


JMP 

TCHAR 



FLUSSDIAGRAMME ALS DOKUMENTATION 

Wir haben bereits die Verwendung von Flußdia- 
grammen als Hilfsmittel bei der Entwicklung in 
Kapitel 13 beschrieben. Flußdiagramme sind 
ebenfalls bei der Dokumentation nützlich, spe¬ 
ziell wenn: 

- sie nicht zu sehr detailliert und dadurch schlecht lesbar sind, 

- ihre Entscheidungspunkte deutlich erklärt und markiert sind, 

- sie alle Verzweigungen beinhalten, 

- sie mit der tatsächlichen Programm Auflistung übereinstimmen 

Flußdiagramme sind nützlich, wenn sie Ihnen einen allgemeinen Überblick über 
das Programm geben. Sie sind von gen ngem Nutzen, wenn sie ebenso schwie¬ 
rig wie eine gewöhnliche Auflistung zu lesen sind. 


STRUKTURIERTE PROGRAMME ALS DOKUMENTATION 

Strukturierte Programme (siehe Kapitel 13) können auch als Teil der Dokumen¬ 
tation dienen, wenn: 

Sie den Zweck jedes Abschnittes in den Kommentaren beschreiben, 

Sie es mit Anweisungen verdeutlichen, die jede bedingte oder ’Schleifen¬ 
struktur beinhaltet, indem Identifizierungs- und Abschlußmarkierungen ver¬ 
wendet werden, 

Sie die gesamte Struktur so einfach wie möglich machen, 

Sie eine konsequente, gut definierte Sprache verwenden. 

Das strukturierte Programm kann Ihnen helfen, die Logik zu prüfen oder sie zu 
verbessern. Ferner, da das strukturierte Programm maschinen-unabhängig ist, 
kann es Ihnen auch bei der Ausführung einiger Aufgaben auf anderen Compu¬ 
tern helfen. 


GRÜNDE FÜR DIE 
VERWENDUNG VON 
FLUSSDIAGRAMMEN 


Gute Kommentare erleichtern Ihnen wesentlich die Änderung eines Programms, 
falls neue Anforderungen auftreten. Versuchen Sie beispielsweise, das letzte 
Programm so zu ändern, daß es: 

- jede nachricht mit ASCII STX (02, B ) beginnt, gefolgt von einem dreisteiligen 
Identilikationscode, gespeichert in den Speicherplätzen IDCODE bis 
IDCODE+2, 

- keine Start- oderStopbits hinzufügt, 

- eine Millisekunde zwischen den Bits wartet, 

- 40 Zeichen sendet, beginnend mit dem einen, das in der Adresse DPTR und 
DPTR+1 liegt, 

- jede Mitteilung mit zwei aufeinanderfolgenden ASCII ETX (03 le ) abschließt 
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SPEICHERPLÄNE 


Ein Speicherplan ist einfach eine Auflistung aller Speicherzuweisungen in 
einem Programm. Der Plan gestattet Ihnen zu bestimmen, wieviel Speicher be¬ 
nötigt wird, die Lage der Daten oder Unterprogramme und die Teile des Spei¬ 
chers, die noch nicht zugewiesen wurden. Der Plan ist eine sehr handliche Re¬ 
ferenz für das Auflinden von Speicherplätzen und Eingabepunkten und für die 
Aulteilung des Speichers zwischen verschiedenen Routinen oder Programmie¬ 
rern. Der Plan wird Ihnen auch einen einfachen Zugriff auf Daten und Unterpro¬ 
gramme geben, wenn Sie diese bei späteren Erweiterungen oder bei der Be¬ 
treuung des Programmes benötigen. Manchmal ist ein grafischer Plan nützlicher 
als eine Auflistung. 

Ein typischer Speicherplan wird folgendermaßen aussehen: _ 

TYPISCHER 

SPEICHER¬ 

PLAN 


Programmspeicher 


Adresse 

Routine 

Zweck 

EOOO-El FF 

INTRPT 

Unterbrechungs-Service Routine für Tastatur 

E200-E240 

BRKPT 

Service-Routine für Break-Befehl 

E241-E250 

DELAY 

Verzögerungsprogramm 

E251-E270 

DSPLY 

Anzeige-Steuerprogramm 

E271-E3F9 

MAIN 

Hauptprogramm 

E3FA-E3FF 


Unterbrechungs- und Reset Vektoren 

Datenspeicher 

0000 

NKEYS 

Anzahl der Tasten 

0001 0002 

KPTR 

Tastatur-Puffer-Zeiger 

0003-0041 

KBFR 

Tastatur-Puffer 

0042-0051 

DBFR 

Anzeige-Puffer 

0051 006F 

TEMP 

Zeitweilige Speicherung 

01 00-01FF 

STACK 

RAM-Stapel 


Erinnern Sie sich daran, daß der RAM-Stapel des 6502 immer auf Seite 1 des 
Speichers liegt. 
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PARAMETER- UND DEFINITIONSLISTEN 


Parameter- und Definiti'onslisten am Beginn des Programms und jedes Unter¬ 
programms machen das Verständnis und Änderungen des Programms wesent¬ 
lich einfacher. Die folgenden Regeln können helfen: 

1) Trennen sie RAM-Speicherplätze, E/A-Einhei- REGELN FÜR 

ten, Parameter, Definitionen und Speichersy- DEFINITIONSLISTEN 
stem-Konstanten. - 

2) Ordnen Sie Listen, wenn möglich, alphabetisch an - mit einer Beschreibung 
jeder Eingabe. 

3) Geben Sie jedem Parameter, der sich ändern könnte, einen Namen und 
nehmen Sie diesen in die Liste auf. Derartige Parameter können Zeitkon¬ 
stanten, Eingaben oder Codes entsprechend spezieller Tasten oder Funktio¬ 
nen, Steuer oder Maskier-Muster, Start- oder Abschlußzeichen, Schwellen 
etc. enthalten 

4) Führen Sie die Speichersystem-Konstanten in einer separaten Liste auf. 

Diese Konstanten werden die Reset- und Unterbrechungs-Service-Adressen 
enthalten, die Start-Adresse des Programms, RAM Bereiche, Stapel-Berei¬ 
che etc. 

5) Geben Sie jedem Port, der von einem E/A-Baustein verwendet wird, einen 
Namen, auch wenn Bausteine sich den gleichen Port in dem momentanen 
System teilen würden. Diese Trennung macht eine Erweiterung oder Neu-An- 
ordnung wesentlich einfacher. 

Eine typische Liste von Definitionen wäre: TYPISCHE 

DEFINTIONS- 

LISTE 


SPEICHERSYSTEM-KONSTANTE 


INTRP -$E200 
RAMST =$0 
RESET -SE300 
STPTR -$01FF 


UNTERBRECHUNGS-EINTR1TFS-PUNKT 
BEGINN DES DATENSPEICHERS 
RESEf-ADRESSE 

BEGINN DES STAPELS IM RAM (AUF SEITE 1) 


lE/A-EINHEITEN 


DSPLY =$A000 ;AUSGABE-VIA FÜR ANZEIGEN 

KBDIN «SA001 ;EINGABE-VIA FQR TASTATUR 

KBDOT =$A000 ;AUSGABE-VIA FÜR TASTATUR 

TIYVIA =$A800 TTY-DATENPORT 

;RAM-SPEICHER 


NKEYS 

*=RAMST 

*-*+1 

.ANZAHL DER TASTEN 

KPTR 

*-*+2 

TASTATUR-PUFFER-ZEIGER 

KBFR 

*-*+$40 

;TASTATUR-EINGABE-PUFFER 

DBFR 

*-*+$10 

iANZEIGE-DATENPUFFER 

TEMP 

**=*+$ 14 

iZEITWEILIGE SPEICHERUNG 
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BIBLIOTHEKS-ROUTINEN 


.PARAMETER 


BOUNCE -2 
GOKEY -10 
MSCNT -SC7 
OPEN -$0F 
TPULS -1 


;ENTPRELL-ZEIT IN MS 
IDENTIFIZIERUNG DER "GCT-TASTE 
;ZÄHLUNG FÜR 1 MS-VERZÖGERUNG 
;MUSTER FÜR OFFENE TASTEN 
IMPULSLÄNGE FÜR ANZEIGEN 


DEFINITIONEN 


ALLHI -$FF 
STCON -$08 


;MUSTER AUS LAUTER EINSEN 
;MUSTER FÜR BEGINN DES UMWANDLUNGS¬ 
IMPULSES 


Natürlich werden die RAM-Eingaben nicht in alphabetischer Reihentolge vorlie¬ 
gen. da der Entwickler diese so anordnen muß, d aßer die Anzahl der Adressen- 
Anderungen, die in dem Programm erforderlich sind, auf ein Minimum hält. 


Eine Standard-Dokumentation von Unterprogrammen wird Ihnen den Aufbau 
einer Bibliothek aus nützlichen Programmen ermöglichen. Der Gedanke be¬ 
steht darin, auf diese Programme so leicht wie möglich zugreifen zu können. Ein 
Standard-Format wird Ihnen oder sonst irgendjemandem gestatten, auf einen 
Blick zu sehen, was das Programm ausführt. Das beste Verfahren besteht in der 
Schaffung einer Standardform und deren konsequente Verwendung. Bewahren 
Sie diese Programme gut organisiert auf (zum Beispiel entsprechend dem Pro¬ 
zessor, Sprache und Arten des Programms), und Sie werden bald eine sehr 
nützliche Sammlung besitzen. Aber erinnern Sie sich daran, daß ohne entspre¬ 
chende Organisation und gute Dokumentation die Verwendung der Bibliothek 
schwieriger sein kann, als das Programm jeweils neu zu schreiben. Das Besei¬ 
tigen von Fehlern in ein4m System erfordert ein genaues Verständnis aller Effek¬ 
te jedes Unterprogramms. 


Informationen, die Sie in der Standardform benö¬ 
tigen werden: 

Zweck des Programms 
Verwendeter Prozessor 
Verwendete Sprache 
Erforderliche Parameter und wie sie zum Unterprogramm übertragen werden. 
Erzeugte Ergebnisse und wie sie zum Hauptprogramm übertragen werden. 
Anzahl der verwendeten Speicherbytes 

Anzahl der erforderlichen Taktzyklen Diese Zahl kann ein Durchschnittswert 
oder ein typischer Wert sein oder auch im weitem Maße variieren. Die tatsäch¬ 
liche Ausführungszeit wird natürlich von der Taktrate des Prozessors abhän- 
gen. 

Beeinflußte Register 
Beeinflußte Flags 
Ein typisches Beispiel 
Handhabung von Fehlern 
Spezielle Fälle 

Dokumentierte Programm-Auflistung 

Wenn das Programm komplex ist, sollte die Standard-Bibliotheksform auch ein 
allgemeines Flußdiagramm oder ein strukturiertes Programm enthalten. Wie wir 
früher eiwähnt haben, ist ein Bibliotheksprogramm wahrscheinlich dann am 
nützlichsten, wenn es eine einzelne bestimmte Aufgabe in verhältnismäßig all¬ 
gemeiner Weise ausführt. 


STANDARD¬ 
FORMEN FÜR 
PROGRAMM¬ 
BIBLIOTHEK 
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BIBLIOTHEKS-BEISPIELE 
Bibliotheks-Beispiel 1: Summe von Daten 

Zweck: Das Programm SUM8 berechnet die Summe eines Satzes von Binär¬ 
zahlen mit 8 Bits und ohne Vorzeichen. 

Sprache: 6502-Assembler 

Anfangsbedingungen: Adresse eins weniger als die Startadresse des Zahlen¬ 
satzes in den Speicherplätzen 0040 und 0041, Länge 
des Satzes im Index-Register Y. 

Abschluß-Bedingungen: Summe in Akkumulator. 

Erfordernisse: 

Speicher - 9 Bytes 

Zeit - 7+12n Taktzyklen, wobei n die Länge des Satzes der 
Zahlen ist Kann länger sein, wenn Seitengrenzen 
überquert werden. 

Register - A.Y 

RAM - Speicherplätze 0040 und 0041 
Alle Flags beeinflußt 

Typischer Fall: (Alle Daten in hexadezimal) 

Start: 

(0040 und 0041) - 004F 
Y - 03 
(0050) - 27 
(0051) - 3E 
(0052) - 26 

Ende: 

A - 8B 

Handhabung der Fehler: Das Programm ignoriert sämtliche Überträge. Das 
Übertrags-Bit gibt nur die letzte Operation wieder 
Anfangsbedingungen des Indexregisters Y müssen 1 
oder mehr sein. Dezimal-Betriebsart-Flag sollte ge¬ 
löscht werden. 

Auflistung: 

;SUMME VON 8-BIT-DATEN 

SUM8 
ADD8 


LDA #0 ;SUMME - NULL 

clc iübertrag löschen jedes mal 

ADC ($40),Y ;SUMME-SUMME + DATENEINGABE 

DEY 

BNE ADD8 
RTS 
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Bibliotheks-Beispiel 2: Dezimal-in-Sieben-Segment- 

Umwandfung 

Zweck: Das Programm SEVEN wandelt eine Dezimalzahl in einen Sieben-Seg- 
ment-Anzeigecode um. 

Sprache: 6502 Assembler. 

Anfangsbedingungen: Daten im Index-Register X. 

Abschlußbedingungen: Siapen-Segment-Code im Akkumulator. 

Erfordernisse: 

Speicher - 19 Bytes, einschließlich der Sieben-Segment-Code- 
Tabelle (10 Eingaben). 

Zeit - 16 Taktzyklen, wenn dezimal, 13 wenn nicht. Kann län¬ 
ger sein, wenn Seitengrenzen überschritten werden. 
Register - A.X 
Alle Flags beeinflußt. 

Eingangsdaten im Index-Register X bleiben unverändert. 

Typischer Fall: (Daten in hexadezimal) 



Fehlerhandhabung: Das Programm gibt Null in den Akkumulator zurück, wenn 
die Daten keine Dezimalzilfern sind. 

Auflistung: 


;DEZIMAL-IN-SIEBEN-SEGMENT-UMWANDLUNG 


SEVEN 

LDA 

#0 

;HOLE FEHLERCODE ZUM AUSTASTEN DER 
: ANZEIGE 


CPX 

#10 

;SIND DIE DATEN DEZIMAL? 


BCS 

DONE 

;NEIN, BEWAHRE FEHLERCODE AUF 

DONE 

LDA 

RTS 

#$SEG,X 

;JA, HOLE SIEBEN-SEGMENTCODE VON 
; TABELLE 

SSEG 

.BYTE 

$3F,$06,$5B,$4F,$66 


.BYTE 

$6D,$7D,$07,$7F,$6F 
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Bibliotheks-Beispiel 3: Dezimale Summe 

Zweck: Das Programm DECSUM addiert zwei Mehrwort-Dezimalzahlen. 

Sprache: 6502-Assembler 

Anfangsbedingungen: Die Adresse der MSBs der einen Zahl liegt in den Spei¬ 
cherplätzen 0040 und 0041, die Adresse der MSBs der anderen Zahl in 
den Speicherplätzen 0042 und 0043. Die Länge der Zahlen (in Bytes) 
liegt im Index-Register Y. Die angeordneten Zahlen beginnen mit den 
höchstwertigen Stellen. 

Abschlußbedingungen: Die Summe ersetzt die Zahl mit der Stait-Adresse in den 
Speicherplätzen 0040 und 0041. 


Erfordernisse: 

Speicher - 14 Bytes 

Zeit - 1 1+22n Taktzyklen, wobei n die Anzahl der Bytes ist. 
Kann länger Sein, wenn Seitengrenzen überschritten 
werden. 

Register - A.Y 

RAM - Speicherplätze 0040 bis 0043 

Alle Flags beeinflußt - Übertrag zeigt, wenn die Summe einen Übertrag 
erzeugt. Dezimal-Betriebsart-Flag wird gelöscht. 

Typischer Fall: (Alle Daten in hexadezimal) 

Start: 

(0040 und 0041) - 0060 
(0042 und 0043) - 0050 
(Y) - 02 

(0060) - 55 
(0061) - 34 

(0050) - 15 
(0051) - 88 

Ende: 

(0060) - 71 
(0061) - 22 
Übertrag - 0 

Fehlerhandhabung: Das Programm überprüft nicht die Gültigkeit von dezimalen 
Eingaben. Der Inhalt des Index-Registers Y muß 1 oder größer sein. 


;MACHE GESAMTE ARITHMETIK DEZIMAL 
iLÖSCHE ÜBERTRAG ZU BEGINN 

.HOLE 2 DEZIMALE STELLEN VON REIHE 1 
lADDIERE 2 STELLEN VON REIHE 2 
;SPEICHERE ERGEBNIS IN REIHE 1 


;KEHRE ZU BINÄRER BETRIEBSART 
; ZURÜCK 


Auflistung: 

DECSUM SED 
CLC 

DECADD DEY 

LDA ($40),Y 
ADC ($42),Y 
STA ($40).Y 
TYA 

BNE DECADD 
CLD 

RTS 
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VOLLSTÄNDIGE DOKUMENTATION 


Die vollständige Dokumenation von Mikroprozes- DOKUMENTATIONS- 

sor-Software wird alle oder die meisten Elemente PAKET 

enthalten, die wir vorher erwähnt haben. 

So kann das vollständige Dokumentations-Paket beinhalten: 

-Allgemeine Flußdiagramme 

- Eine geschriebene Beschreibung des Programms 

- Eine Liste aller Parameter und Definitionen 

- Ein Speicherplan 

- Eine dokumentierte Auflistung des Programms 

- Eine Beschreibung des Testplans und der Test-Ergebnisse 

Die Dokumentation kann auch beinhalten: 

- Flußdiagramme des Programmierers 

- Strukturierte Programme 

Die oben aufgeführten Dokumentationsverfahren sind ein Minimum an Doku¬ 
menten für Nicht-Produktions-Software. Produktions-Software benötigt weit 
größere Anstrengungen bezüglich der Dokumentation. Die folgenden Doku¬ 
mente sollten ebenfalls hergestellt werden: 

- Handbuch für die Programmlogik 

- Anwender-Handbuch 
-Service-Handbuch 

Das Handbuch für die Programmlogik erweitert die geschriebenen Erläuterun¬ 
gen bei der Software. Es sollte für einen technisch kompetenten Anwender ge¬ 
schrieben werden, der möglicherweise nicht die detaillierten Kenntnisse besitzt, 
die bei der Beschreibung der Software vorausgesetzt wird. Das Handbuch für 
die Programmlogik sollt die wichtigsten Ziele des Systems beschreiben, die ver¬ 
wendeten Algorithmen und welche Lösungen hierzu erforderlich waren. 

Es sollte dann ausführlich die verwendeten Datenstrukturen beschreiben und 
zeigen wie diese gehandhabt werden. Es sollte ferner einen Führer darstellen, 
der schrittweise durch die Operationen und das Programm leitet. Schließlich 
sollte es alle speziellen Tabellen oder Graphen beinhalten, die bei der Erklärung 
des Programms behilflich sein können. Code-Umwandlungstabellen, Zustands- 
Diagramme, Übersetzungs-Matrizen und Flußdiagramme sollten ebenfalls darin 
enthalten sein. 
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Das Handbuch für den Anwender ist wahrscheinlich das wichtigste und wird 
trotzdem am häufigsten in der Dokumentation übersehen. Unabhängig davon, 
wie gut die Entwicklung eines Systems ist, hat es keinen Weit, wenn niemand 
die Vorteile dieses Handbuchs voll nützen kann. Das Handbuch für den Anwen¬ 
der sollte in das System für alle Anwender einfuhren und möglichst verständlich 
gehalten sein. Es sollte dann eine detaillierte Erklärung der Eigenschaften des 
Systems und dessen Anwendung liefern. Zahlreiche Beispiele werden zur Erkla- 
rung der Punkte im Text dienlich sein. Eine schrittweise Einführung durch das 
System sollte ebenfalls vorgesehen (und getestet) sein. Programmierer mit de¬ 
taillierten Kenntnissen des Systems verwenden häufig Abkürzungen, die ein Le¬ 
ser im allgemeinen nicht verstehen kann. Eine weitere Besprechung über das 
Schreiben von Anwendar-Handbüchern geht über den Rahmen dieses Buches 
hinaus Erinnern Sie sich jedoch daran, daß Sie niemals zuviel Muhe bei der 
Vorbereitung eines derartigen Handbuches autwenden können, da es sicherlich 
das Dokument sein wird, auf das man sich am häufigsten bezieht. 

Das Service-Handbuch ist für den Programmierer, der das System zu modifi¬ 
zieren hat. Es sollte ausführliche Verfahren. Schntt-für-Schntt, für derartige Re¬ 
konfigurationen beinhalten. Zusätzlich sollte es alle Vorkehrungen ausfuhrhch 
beschreiben, die in dem Programm lür zukünftige Erweiterungen vorgesehen 
sind. 


Die Dokumentation sollte nicht zu leicht genommen werden oder biszum Ende 
der Software-Entwicklung hinausgeschoben werden. Ordnungsmäßige Doku¬ 
mentation, kombiniert mit entsprechenden Programmier-Praktlken, ist nicht 
nur ein wichtiger Teil des endgültigen Produktes, sondern kann auch die Ent¬ 
wicklung selbst vereinfachen, schneller und produktiver machen. Der Entwick¬ 
ler sollte die Dokumentation gewissenhaft und gründlich in jeder Stufe der 
Software-Entwicklung ausführen. 


NEU-ENTWICKLUNG 

Manchmal hat der Entwickler das letzte an Geschwindigkeit oder das letzte 
zusätzliche Byte aus einem Programm herauszuholen. In dem Maße, in dem 
Speicherchips größer wurden, wurde das Speicherproblem weniger ernst. Das 
zeitliche Problem ist natürlich nur dann von Bedeutung, wenn die Anwendung in 
dieser Hinsicht kntisch ist. In den meisten Anwendungen benötigt der Mikropro¬ 
zessor den meisten Teil seiner Zeit zum Warten auf externe Bausteine, und 
die Programm-Geschwindigkeit ist kein wesentlicher Faktor. 


Das endgültige Ausfeilen der Eigenschaften 
eines Programms ist nicht so wesentlich, wie 
einige Programmierer manchmal glauben. An 
erster Stelle wird die Neu-Entwicklung aus 
folgenden Gründen aufwendig: 

1) Es wird zusätzliche Programmierzeit benötigt, die häufig die einzigen hohen 
Kosten in der Software-Entwicklung sind. 

2) Die Neu-Entwicklung lohnt sich, wenn die Struktur und Einfachheit des Pro¬ 
gramms erhöht werden, wodurch sich eine Verringerung der Fehlersuch-Zeit 
und Testzeit ergibt. 

3) Das Programm benötigt zusätzliche Dokumentation. 

4) Das sich ergebende Programm wird schwierig zu erweitern, zu wailen oder 
neuerlich zu verwenden sein. 

An zwe'rter Stelle können die niedrigeren Kosten und die besseren Eigenschaf¬ 
ten vielleicht nicht so wichtig sein. Werden durch die niedrigeren Kosten und 
besseren Eigenschaften tatsächlich mehr Geräte gekauft? Oder wäre es besser, 
mehr anwender-orientierte Eigenschaften unterzubringen? Die einzigen Anwen¬ 
dungen, die diese zusätzlichen Anstrengungen und Zeit rechtfertigen würden, 
sind Anwendungen mit sehr hohen Stückzahlen, niedrigen Kosten und einfa¬ 
chen technischen Eigenschaften, bei denen die Kosten eines zusätzlichen 
Speicherchips die Kosten für die zusätzliche Software-Entwicklung weit über¬ 
steigen. Für alle anderen Anwendungen werden Sie finden, daß man ohne 
Grund einen unverantwortlich hohen Aufwand treibt. 


Wenn Sie jedoch ein Programm überarbeiten 
müssen, so können die folgenden Hinweise von 
Nutzen sein. Bestimmen Sie zuerst, um wieviel 
Sie das Programm verbessern müssen oder um 
wieviel weniger Speicher benötigt wird. Wenn die erforderlichen Verbesserun¬ 
gen 25% oder weniger sind, so könnten Sie den entsprechenden Erfolg durch 
die Neu-Organisah on des Programms erreichen. Liegt es über 25% und Sie 
haben einen grundlegenden Entwicklungsfehler gemacht, werden Sie wahr¬ 
scheinlich drastische Änderungen in der Hardware oder Software ausführen 
müssen. Sie werden sich daher zuerst mit der Neu-Organisation und später mit 
weitgehenden Änderungen befassen. 

Beachten Sie insbesonders, daß die Einsparung von Speicher kritisch sein kann, 
wenn ein Programm in eine begrenzte Größe von ROM oder RAM passen soll, 
das auf einem einfachen Einchip- oder Zweichip-Mikrocomputer verfügbar ist. 
Die Hardware-Kosten für kleine Systeme können dadurch beträchtlich reduziert 
werden, wenn ihre Anforderungen auf die Speichergröße und E/A-Begrenzun- 
gen dieses speziellen Einchip- oder Zweichip-Systems eingeschränkt werden 
können. 


GRÖSSERE ODER 
KLEINERE 

NEUORGANISATION 


KOSTEN DER 
NEU-ENTWICKLUNG 
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REORGANISATION FÜR WENIGER SPEICHER 

Die folgenden Verfahren werden den Speicher- EINSPAREN 

bedarf für Assemblersprachen-Programme des VON SPEICHER _ 

6502 verringern: 

1) Ersetzen Sie im Programmablauf sich wiederholende Codes (In-Line- 
Codes) durch Unterprogramme. Vergewissern Sie sich jedoch, daß die 
Aufruf- und Rückkehr-Befehle nicht wieder den größten Teil des Gewinnes 
verbrauchen. Beachten Sie, daß dieser Ersatz gewöhnlich in langsameren 
Programmen resultiert, da für die Übertragung der Steuerung vorwärts 
und zurück Zeit auf ge wendet werden muß. 

2) Plazieren Sie die am meisten verwendeten Daten auf Seite Null und grei¬ 
fen Sie auf diese mit direkten Einwort-Adressen zu. Sie können vielleicht 
auch einige wenige E/A-Adressen hierher plazieren 

3) Verwenden Sie wenn immer möglich den Stapel. Der Stapelzeiger wird 
automatisch nach jeder Verwendung auf den neuesten Stand gebracht, so 
daß keine ausdrücklichen Befehle für diese Funktion erforderlich sind. Ver¬ 
gessen Sie jedoch nicht, daß der Stapel des 6502 niemals länger als eine 
Seite sein kann. 

4) Beseitigen Sie Sprung-Anweisungen. Versuchen Sie das Programm statt- 
dessen entsprechend neu zu organisieren. 

5) Benützen Sie den Vorteil von Adressen, die Sie mit 8-Bit-Größen handha¬ 
ben können. Diese beinhalten Speicherplätze aut Seite Null und Adressen, 
die ein Vielfaches von 100 18 sind Z.B. könnten Sie versuchen, alle ROM- 
Tabellen in einen 1 O0, e -Byte-Abschnitt des Speichers zu plazieren und alle 
RAM-Variablen in einen weiteren 100, e -Byte-Abschnitt. 

6) Organisieren Sie Daten und Tabellen so, daß Sie sie adressieren können, 
ohne sich wegen Überträgen den Kopf zerbrechen zu müssen oder ohne 
irgendwelche tatsächliche Indizierung. Dadurch werden Sie wieder 16-Bit- 
Adressen als 8-Bit-Größen handhaben können. 

7) Verwenden Sie die Bit-Test-Befehle zur Bearbe itung einer Bit-Position an 
jedem Ende eines Wortes. 

8) Verwenden Sie übrig gebliebene Ergebnisse von früheren Programm-Ab¬ 
schnitten. 

9) Benützen Sie den Vorteil von Befehlen wie ASL, DEC, INC, LSR, ROL und 
ROR, die direkt die Speicherplätze ohne Verwendung von Registern bear¬ 
beiten. 

10) Verwenden Sie INC oder DEC zum Setzen oder Löschen von Flags. 
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11) Verwenden sie relative Sprünge anstatt Sprünge mit direkter Adressie¬ 
rung. 

12) Achten Sie auf spezielle Kurzformen der Befehle wie Verschiebungen des 
Akkumulators (ASL A. LSR A. ROL A und ROR A) und BIT. 

13) Verwenden Sie Algorithmen anstelle von Tabellen zur Berechnung von 
arithmetischen oder logischen Ausdrücken und zur Ausführung von Code- 
Umwandlungen. Beachten Sie, daß dieser Austausch langsamere Program¬ 
me ergeben kann. 

14) Verringern sie dieGröße der mathematTschen Tabellen durch Interpolation 
zwischen den Eingaben. Hier sparen wir wieder Speicher aut Kosten der 
Ausführungszeit. 

15) Benützen Sie den Vorteil der CPX- und CPY-Befehle zur Ausführung von 
Vergleichen ohne den Akkumulator. 

Obwohl einige der Verfahren zur Verringerung EINSPARUNG VON 

des Speicher-Bedarts auch Zeit einsparen, kann AUSFÜHRUNGSZEIT 

man im allgemeinen nur dann entsprechend viel - 

Zelt einsparen, indem man sich auf häufig ausgefühlte Schleifen konzen¬ 
triert. Auch das vollständige Eliminieren eines Befehls, der nur einmal aus¬ 
geführt wird, kann im besten Fall einige wenige Mikrosekunden einsparen. 
Die Ersparnisse in einer Schleife, die wiederholt ausgeführt wird, gibt ein 
Mehilaches hiervon. 

Wenn Sie daher die Ausführungszeit verringern müssen, gehen Sie folgen¬ 
dermaßen vor: 

1) Bestimmen Sie, wie häufig jede Programmschleife durchlaufen wird. 

Sie können dies von Hand ausführen oder durch Verwendung des Soft¬ 
ware-Simulators oder anderer Testmethoden. 

2) Prüfen sie die Schleifen in der Reihenfolge ihrer Häufigkeit der Ausfüh¬ 
rung, beginnend mit der am meisten verwendeten. Gehen Sie weiter durch 
diese Liste, bis Sie die erforderliche Verringerung erzielt haben. 

3) Sehen sie zuerst nach, ob es einige Operationen gibt, die außerhalb der 
Schleife ausgeführt werden, d h. wiederholte Berechnungen, Daten, die in 
ein Register oder in den Stapel plaziert werden können, Daten oder Adres¬ 
sen, die in der Null-Seite gespeichert werden können, spezielle Fälle oder 
Fehler, die extern verarbeitet werden können, etc. Beachten Sie, daß dies 
zusätzliche Initialisierung und Speicher erfordert, jedoch eine beträchtli¬ 
che Einsparung an Zeit bewirkt. 

4) Versuchen Sie Sprung-Adressen zu eliminieren. Diese benötigen sehr viel 


5) Ersetzen Sie Unterprogramme durch einen ”ln-Line"-Code. Dies wird we¬ 
nigstens einen Sprung zu einem Unterprogramm und eine Rückkehr von 
einen Unterprogramm sparen. 


15-21 




6) Verwenden Sie den Stapel für zeitweilige Datenspeicherung. 

7) Verwenden Sie jeden der Hinweise für die Einsparung von Speicher, der 
auch die Ausführungszelt verringern wird. Diese beinhalten die Verwen¬ 
dung von 8-Bit-Adressen, BRK, RTI, spezielle Kurzformen von Befehlen etc. 

8) Sehen Sie sich nicht Befehle an, die nur einmal ausgeführ t werden. Jede 
Änderung, die Sie bei solchen Befehlen machen, bringt meist nur Fehler, 
und der Gewinn ist ohne Bedeutung. 

9) Vermeiden Sie indizierte und indirekte Adressierung, wann immer mög¬ 
lich, da diese zusätzliche Zeit benötigen. 

10) Verwenden Sie Tabellen anstelle von Algorithmen. Bauen Sie die Tabellen 
so auf. daß Sie soviel wie möglich Aufgaben ausführen können, auch wenn 
zahlreiche Eingaben wiederholt werden müssen. 
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GRÖSSERE REORGANISATIONEN 


Wenn Sie mehr als 25% Steigerung der Geschwindigkeit oder Verringerung 
des Speicherbedarfs benötigen, versuchen Sie nicht den Code neu zu organi¬ 
sieren. Ihre Chancen, mehr als einige kleine Verbesserungen zu erzielen, sind 
gering, außer Sie können einen zusätzlichen Experten hinzuziehen. Sie sind im 
allgemeinen besser daran, wenn Sie eine größere Änderung durchführen. 

Die offensichtlichste Änderung ist ein besserer BESSERE 

Algorithmus. Speziell, wenn Sie Dinge wie Sor- ALGORITHMEN 

tieren, Suchen oder mathematische Berechnun¬ 
gen ausführen wollen, werden Sie imstande sein, eine schnellere oder kürzere 
Methode als in der Literatur beschrieben zu finden. Bibliotheken von Algorith¬ 
men sind in einigen Zeitschriften und von professionellen Gruppen 
verfügbar. Sehen Sie sich beispielsweise die Literatur am Ende dieses dieses 
Kapitels an 

Mehr Hardware kann einen Teil der Software ersetzen. Zähler, Schieberegister, 
arithmetische Einheiten. Hardware-Multiplikatoren und andere schnelle Zusatz¬ 
teile können sowohl Zeit wie Speicher sparen. Rechner, UARTs, Tastaturen, 
Codierer und andere langsame Zusatzgeräte können zwar Speicher sparen, ar¬ 
beiten dafür aber langsamer. Kompatible parallele und serielle Interface-Schal¬ 
tungen und andere Bausteine, die speziell zur Verwendung mit dem 6502 oder 
6800 geschaffen wurden, können Zeit sparen, indem sie einige Aufgaben der 
CPU übernehmen. 

Andere Änderungen können ebenfalls helfen: ANDERE 

WESENTICHE 

1) Eine CPU mit einem längeren Wort wird schneller sein, ÄNDERUNGEN 

wenn die Daten lang genug sind. Eine derartige CPU 
wird insgesamt weniger Speicher benötigen 16-Bit- 
Prozessoren verwenden Speicher effizienter als 8-Bit- 
Prozessoren, da zahlreiche ihrer Befehle ein Wort lang 
sind. 

2) Es können Versionen der CPU existieren, die mit höheren Taktraten arbei¬ 
ten. Aber erinnern Sie sich daran, daß Sie dann ebenfalls schnellere Speicher 
und E/A Ports benötigen und daß Sie jede Verzögerungsschleife neu anord¬ 
nen müssen. 

3) Zwei CPUs können imstande sein, die Aufgabe parallel oder getrennt aus¬ 
zuführen, wenn Sie die Aufgabe unterteilen können und die Kommumkations- 
probleme lösen. 

4) Ein spezieller mikroprogrammierter Prozessor kann imstande sein, das glei¬ 
che Programm wesentlich schneller auszuführen. Die Kosten sind jedoch 
wesentlich höher, auch wenn Sie eine handelsübliche Emulation benützen. 

5) Sie können Überlegungen zwischen Zeit und Speicher anstellen. Nach- 
schlage-Tabellen und Funktions-ROMs wären schneller als Algorithmen, wür¬ 
den jedoch mehr Speicher belegen 
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Eine derartige Aufgabe, bei der große Verbesse¬ 
rungen erforderlich sind, resultiert gewöhnlich 
aus mangelnder Planung bei der Definition und 
in den Entwicklungsstufen. Bei der Stufe der 
Aufgaben-Definition sollten Sie bestimmen, welcher Prozessor und welche 
Methoden ausreichend für die Lösung der Aufgabe sind. Wenn Sie eine Fehl- 
Entscheidung treffen, werden die Kosten später sehr hoch sein. Eine billige 
Lösung kann in einem unerwarteten Aufwand von kostspieliger Entwicklungs¬ 
zeit resultieren. Hieran werden sie aber nicht vorbeikommen. Die beste Lö¬ 
sung für die richtige Entwicklung und die Vermeidung von Fehlern besteht ge¬ 
wöhnlich in der entsprechenden Erfahrung. Wenn Sie derartige Methoden wie 
die Aufstellung von Flußdiagrammen, modularer Programmierung, strukturier¬ 
ter Programmierung, Entwicklung mit schrittweiser Verfeinerung und die ent¬ 
sprechende Dokumentation ausgeführt haben, werden Sie imstande sein, eine 
Menge der aufgewendeten Mühe zu retten, falls Sie eine größere Änderung 
auszuführen haben. 


ENTSCHEIDUNG FÜR 
EINE GRÖSSERE 
ÄNDERUNG 
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Kapitel 16 
BEISPIELE 


Projekt Nr. 1: Eine digitale Stoppuhr 


Zweck: Dieses Projekt stellt eine digitale Stoppuhr dar. 

Der Bedienende gibt zwei Zittern (Minuten und 
Zehntel-Minuten) über eine rechner-ähnliche Ta¬ 
statur ein und drückt dann die GO-Taste. 

Das System zählt die verbleibende Zeit auf zwei Sieben-Segment-LED- 
Anzeigen abwärts (siehe Kapitel 11 tur eine Beschreibung von nicht co¬ 
dierten Tastaturen und LED-Anzeigen). 

Hardware: Das Projekt verwendet einen Eingangs- und einen Ausgangsport 
(einen universellen Interiace-Adapter 6522 VIA), zwei Sieben-Segment-Anzei- 
gen, eine Tastatur mit 12 Tasten, einen Inverter 7404 und entweder ein NAND- 
Gatter 7400 oder ein UND-Gatter 7408. abhängig von der Polarität der Sieben- 
Segment-Anzeige. Die Anzeigen können Treiber, Inverter und Widerstände er¬ 
fordern, abhängig von ihrer Polarität und Konfiguration. 

Die Hardware ist wie in Bild 16-1 gezeigt konfiguriert. Die Ausgangsleitungen 0, 
1 und 2 werden zur Abtastung der Tastatur verwendet Die Eingangsleitungen 0, 
1, 2 und 3 werden verwendet, um zu bestimmen, ob irgendeine der Tasten ge¬ 
drückt wurde. Die Ausgangsleitungen 0, 1, 2 und 3 dienen zum Senden von 
BCD-Ziffern zu den Sieben-Segment-Decoder/Treibern. Die Ausgangsleitung 4 
wird zum Aktivieren der LED-Anzeigen verwendet (wenn die Leitung 4 gleich ” 1 ” 
ist. so leuchtet die Anzeige). Die Ausgangsleitung 5 dient zur Auswahl der lin¬ 
ken oder rechten Anzeige. Die Ausgangsleitung 5 ist "1", wenn die linke Anzei¬ 
ge verwendet wird. "0". wenn die rechte Anzeige verwendet wird. Daher sollte 
die gemeinsame Leitung an der linken Anzeige aktiv sein, wenn die Leitung 4 
gleich ”1” und die Leitung 5 gleich "1" ist, während die gemeinsame Leitung an 
der rechten Anzeige aktiv sein sollte, wenn Leitung 4 gleich ”1" und Leitung 5 
gleich "0” ist. Die Ausgangsleitung 6 steuert den Dezimalpunkt an der linken 
Anzeige. Er kann mittels eines Inverters gesteuert werden oder einfach einge¬ 
schaltet bleiben. 

Tastatur-Verbindungen: Die Tastatur ist eine einfache Rechner-Tastatur, die 
äußerst billig im Handel erhältlich ist. Sie besteht aus 1 2 nicht-codierten Tasten¬ 
schaltern, die in vier Reihen zu je drei Spalten angeordnet sind. Da die Verdrah¬ 
tung der Tastatur nicht mit den vorgesehenen Reihen und Spalten überein¬ 
stimmt, verwendet das Programm eine Tabelle zur Identifizierung der Tasten. 
Die Tabellen 16-1 und 16-2 enthalten die Eingangs- und Ausgangs-Verbindun¬ 
gen für die Tastatur. Die Taste für den Dezimalpunkt dient zur Bequemlichkeit 
des Bedienenden und für zukünftige Erweiterungen. Das momentane Programm 
verwendet diese Taste nicht. 


STOPPUHR- 

EINGABE¬ 

VERFAHREN 
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Bei einer tatsächlichen Anwendung würde die Tastatur Pullup-Widerstände be¬ 
nötigen um zu sichern, daß die Eingaben wirklich als logische Einsen ge¬ 
lesen werden, wenn die Tasten nicht gedrückt sind. Es wären ebenfalls strombe¬ 
grenzende Widerstände oder Treiber mit offenen Kollektoren am Ausgangs-Port 
erforderlich, um die Beschädigung der VIA-Treiber in dem Pall zu vermeiden, 
bei dem zwei Ausgänge gegeneinander arbeiten. Dies könnte auftreten, wenn 
zwei Tasten in der gleichen Reihe zur selben Zeit gedrückt werden, wodurch 
zwei verschiedene Spalten-Ausgänge miteinander verbunden werden. 



Bild 16-1. E/A-Konfiguration für digitale Stoppuhr. 


Tabelle 16-1. Eingangs-Verbindungen für Stoppuhr-Tastatur 


Eingangs-Bit 

Angeschlossene Tasten 

0 

•3 '6 8 

1 

2 6 9 

2 

Cf i 7 

3 

4 Y GO 


Tabelle 16-2. Ausgangs-Verbindungen für Stoppuhr-Tastatur 


Ausgangs-Bit 

Angeschlossene Tasten 

0 

0. 2.3. 4 

1 

18 ‘9 . GO 

2 

5 . 6\ 7\ 7 
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Verbindungen für die Anzeige: Die Anzeigen sind standardisierte 7-Segment- 
Anzeigen mit eingebauten Decodern. Natürlich wären nicht-decod leite 
7-Segment-Anzeigen billiger, sie würden jedoch zusätzliche Software benötigen 
(eine Routine für eine 7 -Segment-Umwandlung ist in Kapitel 7 gezeigt). Die Da¬ 
ten werden in die Anzeige als eine einzelne binär codierte Dezimalziffer einge¬ 
geben, Die Ziffern werden wie in Bild 11-22 gezeigt dargestellt Der Dezimal¬ 
punkt ist eine einzelne LED. die eingeschaltet wird, wenn der Dezimalpunkt€m- 
gang logisch 1 ist. Sie können weitere Informalionen über Anzeigen in der Lite¬ 
ratur 12 und 1 3 am Ende dieses Kapitels linden. 


Prograrfimbeschreibung: 

Das Programm ist modular und besitzt mehrere Unterprogramme. Das Schwer¬ 
gewicht wurde mehr auf die Deutlichkeit und die Allgemeingültigkeit gelegt an¬ 
statt auf die Effizienz. Offensichtlich nützt das Programm nicht die vollen Mög¬ 
lichkeiten des Prozessors 6502. Jeder Abschnitt der Auflistung wird nun im De¬ 
tail beschrieben. 


1) Einführende Kommentare 

Die einführenden Kommentare beschreiben das Programm vollständig. 
Diese Kommentare dienen als Referenz, so daß andere Anwender das Pro¬ 
gramm leicht anwenden, erweitern und verstehen können. Standardformate, 
Einrückungen und Abstände erhöhen die Lesbarkeit des Programms. 

2) Definition der Variablen 

Alle Definitionen der Variablen sind an den Anfang des Programms plaziert, 
so daß sie leicht geprüft und geändert werden können. Jede Variable liegt in 
einer alphabetischen Liste zusammen mit anderen Variablen der gleichen 
Art. Kommentare beschreiben die Bedeutung jeder Variablen. Die Katego¬ 
rien sind: 

a) Speichersystem-Konstanten, die von System zu System variieren kön¬ 
nen, abhängig vom Speicherraum, der unterschiedlichen Programmen 
oder verschiedenen Speicher-Typen zugewiesen ist 

b) Zeitweilige Speicherung (RAM), die für Variable verwendet wird 

c) E/A- (VIA ) Adressen. 

d) Definitionen. 

Die Speichersystem-Konstanten sind in den Definitionen enthalten, so daß 
der Anwender das Programm, zeitweilige Speicher und den Speicherstapel 
umstellen kann, ohne irgendwelche andere Änderungen ausführen zu müs¬ 
sen. Die Speicher-Konstanten können zur Anpassung an andere Program¬ 
me geändert werden oder um mit einer speziellen System-Zuweisung von 
RAM- oder ROM-Adressen übereinzustimmen. 

Zeitweilige Speicherung wird mittels Weitersteilung des Stellenzählers (Re¬ 
serve Memory Byte) zugewiesen, wie in Kapitel 3 gezeigt wurde. Eine - 
(Equate) Pseudo Operation plaziert die zeitweiligen Speicherplätze. Eine 
ORG-Pseudo-Operation plazierl die zeitweiligen Speicherplätze in einen 
speziellen Teil des Speichers, In diese Speicherplätze werden keine Werte 
plaziert, so daß das Programm eventuell in ROM oder PROM liegen könnte 
und das System ohne neuerliches Laden nach einem Einschalten der Be¬ 
triebspannung arbeiten könnte. 

Jede Speicheradresse, die von einem VIA belegt wird, ist so bezeichnet, 
daß die Adressen leicht für die Handhabung verschiedener Konfigurationen 
geändert werden können. Die Bezeichnungen dienen auch zur deutlichen 
Unterscheidung der Steuerregister von Datenregistern. 

Die Definitionen machen die Bedeutung bestimmter Konstanten deutlich 
und gestatten eine einfache Änderung von Parametern. Jede Definition ist in 
der Form angegeben (binär, hexadezimal, oktal, ASCII oder dezimal), in der 
ihre Bedeutung am deutlichsten ist. Parameter (wie etwa Entprellzeit) wer¬ 
den hier plaziert, so daß sie entsprechend der Anforderungen des Systems 
variiert werden können. 
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3) Initialisierung 


6) Identifizieren eines Tasten-SchlieGens 


Die Speicherplätze FFFC und FFFD (die RESET Speicherplätze des 6502) 
enthalten die Adresse des Startpunktes des Hauptprogrammes. Das Haupt¬ 
programm kann daher überall in den Speicher plaziert und über das RESET- 
Signal erreicht werden. 

Die Initialisierung besteht aus drei Schritten: 

a) Plazieren eines Startwertes in den Stapelzeiger. Der Stapel wird nur zur 
Speicherung der Unterprogramm-Rückkehr Adressen verwendet. 
Beachten Sie. daß der Stapelzeiger nur 8 Bit lang ist, da sich der Stapel 
des 6502 immer auf Seite eins des Speichers befindet 

b) Konfigurieren des VIA 

c) Starten der Anzahl derZifferntasten, die bei null gedrückt werden. 

4) Ausschauhalten nach einer geschlossenen Taste 


Flußdiagramm: 




Tastenbetätigungen werden dadurch identifziert. indem alle Tastatur Spal¬ 
ten auf Masse gelegt werden und dann auf an Masse liegende Reihen ge¬ 
prüft wird (d.h. Spalten zu-Reihen Schalter geschlossen). Beachten Sie, daß 
das Programm nicht annimmt, daß die unbenutzten Eingangs Bits alle High 
sind. Stattdessen werden die zu der Tastatur gehörenden Bits mit einem 
logischen UND-Befehl maskiert. 

5) Tasten-Entprellung 

Das Programm entprellt das Schließen einer Taste mittels Software, indem 
es zwei Millisekunden wartet. Dies ist im allgemeinen lang genug, um einen 
einwandfreien Kontakt herzustellen. Das Unterprogramm DELAY zählt ein¬ 
fach mit dem Indexregister X eine Millisekunde lang. Die Anzahl der Millise¬ 
kunden liegt im Indexregister Y DELAY müßte neu eingestellt werden, wenn 
ein langsamerer Takt oder langsamerer Speicher verwendet würden. Sie 
können diese Änderungen einfach dadurch ausführen, indem Sie die Kon¬ 
stante MSCNT neu definieren 


Eine geschlossene Taste wird durch an Masse Legen einzelner Spalten und 
Beobachten, ob ein Schließen festgestellt wird, identifziert. Sobald ein 
Schließen festgestellt wurde (so daß die Tastenspalte bekannt ist), kann die 
Tastenreihe durch Verschiebendes Einganges bestimmt werden, bis ein an 
Masse liegendes Bit gefunden wird. 

Das Ausgangsmuster, das erforderlich ist, um einzelne Tastatur-Spalten an 
Masse zu legen, wird durch Verschieben des ursprünglichen Musters um 
ein Bit nach links erhalten, nachdem jede Spalte geprüft wurde. Die höchste 
numerierte Taste der Tastatur wird als eine Marke verwendet, um anzuzei¬ 
gen. daß alle Spalten an Masse gelegt wurden, ohne daß ein Schließen 
einer Taste gefunden wurde. Wenn dieser Wert erreicht ist, wird der Fehler¬ 
code FF in den Akkumulator plaziert, um anzuzeigen, daß das Hauptpro¬ 
gramm das Schließen nicht identifizieren konnte (d.h. daß das Tasten- 
Schließen beendet ist oder ein Hardware-Fehler auftrat). 
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Die Tasten-Identifizierungen liegen in der Tabelle KTAB 
im Speicher. Die Tasten in der ersten Spalte (die den 
niedrigstwertigen Ausgangsbits zugewiesen sind) wer¬ 
den von jenen in der zweiten Spalte gefolgt, etc. Innerhalb einer Spalte 
ist die Taste in der Reihe, die zum niedrigstwertigen Eingangsbit gehört, die 
erste etc. Daher muß jedesmal beim Abtasten einer Spalte ohne Finden 
einer geschlossenen Taste die Anzahl der Tasten in einer Spalte (NROWS) 
zum Tastentabellen-Zeiger addiert werden, um zur nächsten Spalte zu ge¬ 
langen. Der Tastentabellen-Zeiger wird ebenfalls um eins inkrementiert, be¬ 
vor jedes Bit in den Reihen-Eingängen geprüft wird. Dieser Vorgang stoppt, 
wenn ein Null-Eingang gefunden wurde. Beachten Sie, daß der Tastentabel- 
len-lndex bei —1 initialisiert wird, da er immer um eins beim Suchen nach der 
richtigen Reihe inkrementiert wird. 

Wenn wir das Schließen einer Taste nicht identifizieren können, ignoneren 
wir sie einfach und halten nach einer weiteren geschlossenen Taste Aus¬ 
schau. 

7) Vorgang bei der Tasten-Identifizierung 

Wenn das Programm genügend Ziffern (zwei in diesem einfachen Fall) hat, 
halt es nur nach der GO-Taste Ausschau und ignoriert alle anderen Tasten. 
Wenn es eine Zifferntaste findet, bewahit es den Wert in der Tasten-Anord- 
nung auf, inkrementiert die Anzahl der gedrückten Ziffern-Tasten und inkre¬ 
mentiert den Tastenanordnungs-Zeiger. 

Wenn die Eingabe nicht vollständig ist, muß das Programm auf das Ende 
des Schließens der Taste warten, damit das System nicht die gleiche Ta- 
sten-Betätigung neuerlich liest Der Anwender muß zwischen den Tasten- 
Betätigungen warten (d.h. eine Taste loslassen, bevor eine andere gedrückt 
wird) Beachten Sie. daß das Programm doppelte Tasten-Betätigungen als 
eine oder die andere Taste identifizieren wird, abhängig davon, welche Be¬ 
tätigung die Identitizierungs-Routine zuerst auflindet Eine verbesserte Ver¬ 
sion dieses Programms würde die Ziffern so anzeigen, wie sie eingegeben 
werden und würde dem Anwender gestatten, eine führende oder nacheilen¬ 
de Null wegzulassen (d h. das Eintasten von "7", "GO", um die Zählung 
von sieben Zehntel-Minuten zu erhalten). 

ß) Einstellung des Anzeige-Ausgangs 

Die Ziffern werden in Register oder Speicherplätze mit gesetztem Bit 4 pla¬ 
ziert, so daß das Ausgangssignal zu den Anzeigen gesendet wird. Die Bits 5 
und 6 werden für die höchstwertige Stelle gesetzt, um das Ausgangssignal 
zur linken Anzeige zu führen und den Dezimalpunkt einzuschalten 

9) Pulsen der LED-Anzeigen 

Jede Anzeige wird zwei Millisekunden lang eingeschaltet. Dieser Vorgang 
wird 1500mal wiederholt, um eine gesamte Verzögerung von 0.1 Minuten 
oder 6 Sekunden zu erhalten. Die Impulse wiederholen sich in so rascher 
Folge, daß die LED-Anzeigen kontinuierlich eingeschaltet erscheinen 


10) Dekrementieren der Anzeige-Zählung 
Flußdiagramm: 



Der Wert der niedrigstwertigen Stelle wird um eins verringert. Wenn 
dies Bit 4 beeinflußt (LEDON - verwendet zum Einschalten der Anzei¬ 
gen), ist die Ziffer negativ geworden. Dann muß ein "Borgen" von der 
höchstwertigen Stelle erhalten werden. Wenn das Borgen von der hö¬ 
herwertigen Stelle Bit 4 beeinflußt, hat die Zählung null überschritten 
und der "Countdown" ist beendet. Andernfalls setzt das Programm die 
medngslwertige Stelle auf 9 und läuft weiter. 

Beachten Sie, daß die Kommentare beide Abschnitte des Programms und die 
individuellen Anweisungen beschreiben. Kommentare erklären, was das Pro¬ 
gramm ausführt, nicht was der spezielle Befehlscode macht. Um die Lesbarkeit 
zu verbessern, wurden Abstände und Einrückungen verwendet. 


TASTEN¬ 

TABELLE 
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NAME DES PROGRAMMS: STOPPUHR 
DATUM: 4/28/79 

PROGRAMMIERER: LANCE A. LEVENTHAL 
PROGRAMM-ANFORDERUNGEN: DD(221) BYTES 
BENÖTIGTES RAM: 5 BYTES 

E/A-ANFORDERUNGEN: 1 EINGANGSPORT, 1 AUSGANGSPORT (1 VIA 6522) 

DIESES PROGRAMM STELLT EINE DIGITALE STOPPUHR DAR, DIE EINGA¬ 
BEN VON EINER RECHNER-ÄHNLICHEN TASTATUR EMPFÄNGT UND 
DANN EIN COUNTDOWN AUF ZWEI SIEBEN-SEGMENT-LED-ANZEIGEN IN 
MINUTEN UND ZEHNTELMINUTEN LIEFERT 

TASTATUR 

ES WIRD EINE TASTATUR MIT 1 2 TASTEN ANGENOM MEN 
ES GIBT DREI SPALTEN-VERBINDUNGEN ALS AUSGÄNGE VOM 
PROZESSOR, SO DASS EINE TASTENSPALTE AN MASSE GELEGT 
WERDEN KANN 

VIER REIHENVERBINDUNGEN SIND EINGÄNGE ZUM PROZESSOR, SO DASS 
DIE TASTEN IDENTIFIZIERT WERDEN KÖNNEN 
DIE TASTATUR IST ENTPRELLT DURCH WARTEN FÜR DIE DAUER VON 2 
MILLISEKUNDEN, NACHDEM EIN TASTENSCHLIESSEN ERKANNT WURDE 
EIN NEUES TASTENSCHLIESSEN WIRD DURCH WARTEN AUF DAS ENDE DES 
ALTEN SCHLIESSENS IDENTIFIZIERT, DA KEIN TAST-IMPUS VERWENDET 
WIRD 

DIE TASTATURSPALTEN SIND MIT DEN BITS 0 BIS 2 DES PORTS B DES VIA 
VERBUNDEN 

DIE TASTATURREIHEN SIND MIT DEN BITSO BIS 3 DES PORTS A DES VIA 
VERBUNDEN 

ANZEIGEN 

ES WERDEN ZWEI SIEBEN-SEGMENT-LED-ANZEIGEN MIT GETRENNTEN 
DECODERN (7447 ODER 7448, ABHÄNGIG VON DER ART DER ANZEIGEN) 
VERWENDET 

DIE DATEN-EINGÄNGE DES DECODERS SIND MIT DEN BITSO BIS 3 DES 
B-PORTS DES VIA VERBUNDEN 

BIT 4 DES B-PORTS DES VIA WIRD ZUM AKTIVIEREN DER LED-ANZEIGEN 
VERWENDET (BIT 4 IST 1 ZUM SENDEN DER DATEN ZU DEN LEDS) 

BIT 5 DES B-PORTS DES VIA WIRO ZUR AUSWAHL VERWENDET, 

WELCHE LED GERADE VERWENDET WIRD (BITS IST 1, WENN DIE 
FÜHRENDE ANZEIGE VERWENDET WIRD, 0 WENN DIE FOLGENDE 
ANZEIGE VERWENDET WIRD) 

BIT 6 DES B PORTS DES VIA WIRD ZUM EINSCHALTEN DES 
DEZIMALPUNKTES AUF DER FÜHRENDEN ANZEIGE VERWENDET (BIT 6 
IST 1, WENN DIE ANZEIGE EINZUSCHALTEN IST) 


VERFAHREN 

SCHRITT 1 - INITIALISIERUNG 

DER SPEICHERSTAPEL-ZEIGER (VERWENDET FÜR UNTERPROGRAMM¬ 
RÜCKKEHRADRESSEN) WIRD INITIALISIERT DIE ANZAHL DER 
GEDRÜCKTEN ZIFFERNTASTEN WIRD AUF NULL GESETZT. 

SCHRITT 2-FESTSTELLEN EINESTASTENSCHLIESSENS 
ALLE TASTATURSPALTEN WERDEN AN MASSE GELEGT, UND DIE 
TASTATURREIHEN WERDEN GEPRÜFT, BIS EINE GESCHLOSSENE TASTE 
GEFUNDEN WIRD 

SCHRITT 3 - ENTPRELLEN DER TASTEN 
EIN WARTEN VON 2 MS WIRD ZUM ELIMINIEREN DES TASTENPRELLENS 
EINGEFÜHRT 

SCHRITT 4 - IDENTIFIZIERUNG EINES TASTENSCHLIESSENS 
DAS TASTENSCHLIESSEN WIRD DURCH LEGEN EINER EINZELNEN 
TASTATURSPALTE AN MASSE UND BESTIMMEN DER REIHE UND SPALTE 
IDENTIFIZIERT. ES WIRD EINE TABELLE ZUM CODIEREN DER TASTEN 
ENTSPRECHEND IHRER REIHEN- UND SPALTENNUMMERN VERWENDET 
IN DER TASTENTABELLE WERDEN DIE ZIFFERN DURCH IHRE WERTE 
IDENTIFIZIERT. DIE DEZIMALPUNKT-TASTE IST NUMMER 10 UND DIE 
"GO"-TASTE IST NUMMER 11 
SCHRITT 5 - AUFBEWAHREN DES TASTENSCHLIESSENS 
DAS SCHLÜSSEN DER TASTEN WIRD IN DER ZIFFERNTASTEN¬ 
ANORDNUNG AUFBEWAHRT, BIS ZWEI ZIFFERN IDENTIFIZIERT WURDEN. 
DEZIMALPUNKTE, WEITERE ZIFFERN UND BETÄTIGUNGEN DER 
’ GO”-TASTE WERDEN, BEVOR ZWEI ZIFFERN EINGEGEBEN WURDEN, 
IGNORIERT. 

NACHDEM ZWEI ZIFFERN GEFUNDEN WURDEN, WIRD DIE 
"GO " TASTE ZUM STARTEN DES COUNTDOWN VORGANGS VERWENDET 
SCHRITT 6 - COUNTDOWN-ZEITGEBERINTERVALL AUF DEN LEDS 
EIN COUNTDOWN WIRD AUF DEN LEDS AUSGEFÜHRT, WOBEI DIE 
FÜHRENDE STELLE DIE VERBLEIBENDE ZAHL DER MINUTEN UND DIE 
FOLGENDE STELLE DIE ZAHL DER VERBLEIBENDEN ZEHNTELMINUTEN 
DARSTELLT 


DEFINITIONEN DER STOPPUHR-VARIABLEN 


;SPEICHERSYSTEM-KONSTANTEN 


BEGIN -$0400 

STKBGN -$FF 
TEMP -0 


BEGINN IST DER START-SPEICHERPLATZ 
FÜR DAS PROGRAMM 
BEGINN DER STAPELADRESSE AUF SEITE 1 
STARTADRESSE FÜR DEN RAM-SPEICHER 


ZEITWEILIGER RAM-SPEICHER 


*-TEMP 
DCTR *-*+2 
KEYNO *-*+2 


NKEYS *-*+1 


1 6-BIT-ZÄHLER FÜR ZEITSCHLEIFE 
ZIFFERNTASTEN-ANORDNUNG - SIE 
BEWAHRT DIE IDENTIFIZIERUNGEN DER 
ZIFFERNTASTEN AUF, DIE GEDRÜCKT 
WORDEN SIND 
;ANZAHL DER GEDRÜCKTEN 
ZIFFERNTASTEN 
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.E/A-EINHEITEN UND VIA-ADRESSEN 


VIAORB =>$A000 

VIAORA =--$A001 
VIADDRB-SA002 
VIADDRA-SA003 

VIAPCR -SAOOC 


AUSGANGS PORT FÜR TASTATUR UND 
ANZEIGE 

EINGANGS-PORT FÜR TASTATUR 
DATEN-RICHTUNGS-REGISTER FÜR PORT B 
DATEN-RICHTUNGS-REGISTER FÜR 
PORT A 

PERIPHERESSTEUERREGISTER DES VIA 


iDEFINITIONEN 


DECPT 

-%01000000 

ECODE 

-SFF 

GOKEY 

-TI 

KLAST 

LEDON 

.11 

-%00010000 

LEDSL 

=-%00100000 

MSCNT 

«$C7 

MXKEY 

-2 

NROWS 

OPEN 

=4 

=%00001111 

TPULS 

-2 

TWAIT 

=2 


CODE ZUM EINSCHALTEN DER 
DEZIMALPUNKT-LED 
FEHLERCODE. WENN ID-ROUTINE DIE 
TASTE NICHT FINDET 
IDENTIFIZIERUNGS-NUMMER FÜR 
"GO'-TASTE 

HÖCHSTE NUMERIERTE TASTE 
CODE ZUM SENDEN VON AUSGABEN ZU 
DEN LEDS 

CODE ZUR AUSWAHL DER FÜHRENDEN 
ANZEIGE 

ZÄHLUNG, ERFORDERLICH FÜR EINE 
VERZÖGERUNG VON 1 MS 
MAXIMALE ANZAHL DER VERWENDETEN 
ZIFFERNTASTEN-SCHLIESSUNGEN 
ANZAHL DER REIHEN IN DERTASTATUR 
EINGABE VON TASTATUR, WENN KEINE 
TASTE GESCHLOSSEN 
ANZAHL DER MS ZWISCHEN DEN 
ZIFFERN-ANZEIGEN 

ANZAHL OER MS ZUM ENTPRELLEN DER 
TASTEN 


*=$FFC 

IrÜCKSETZ-ADRESSE, UM ZUM STOPPUHR PROGRAMM ZU GELANGEN 

WORD BEGIN ;VEKTOR ZUM STARTEN DES 

; STOPPUHR-PROGRAMMS 
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INITIALISIERUNG DES STOPPUHR-PROGRAMMS 


*=BEGIN 
LDA #0 
STA VIADDRA 

STA VIAPCR 

LDA #$FF 
STA VIADDRB 

LDX #STKBGN 
TXS 


;MACHE VIA A-PORT ZU 
; EINGANGSLEITUNGEN 
MACHE ALLE STEUERLEITUNGEN ZU 
I EINGÄNGEN 

IMACHE VIA B-PORTZU 
; AUSGANGSLEITUNGEN 
.INITIALISIERE STAPELZEIGER 


.INITIALISIERE ZIFFERNTASTEN-ZÄHLER 
,RT ZU 

I AUSGANGSLEITUNGEN 

LDX #STKBGN INITIALISIERE STAPELZEIGER 


INITIALISIERE ZIFFERNTASTEN-ZÄHLER 

INITL LDA #0 ;ANZAHL DER ZIFFERNTASTEN» NULL 

STA NKEYS 


lABTASTEN DER TASTATUR UND AUSSCHAU HALTEN NACH 
; GESCHLOSSENEN TASTEN 

SRCHK JSR SCANC ;WARTE AUF SCHLIESSEN EINER TASTE 

;WARTE AUF DAS ENTPRELLEN EINER TASTE 


LDY #TWAIT ;HOLE ENTPRELLZEIT IN MS 

JSR DELAY ;WARTE AUF EINE TASTE ZUM STOPPEN 

; DES ENTPRELLENS 

IDENTIFIZIERE DIE GEDRÜCKTE TASTE 


JSR IDKEY 
CMP # ECODE 
BEQ SRCHK 


IDENTIFIZIERE DIE GESCHLOSSENE TASTE 
;WELCHE TASTE WURDE IDENTIFIZIERT? 
NEIN. WARTE AUF DAS NÄCHSTE 
SCHLIESSEN 


•STARTE ZEITZÄHLUNG. WENN "GO"-TASTE GEDRÜCKT UND GENÜGEND 
; ZIFFERN VORLIEGEN 

LDX NKEYS ;WURDE DIE MAXIMALE ANZAHL VON 

„ , I ZIFFERNTASTEN EINGEGEBEN? 

CPX #MXKEY 

BNE ENTDG .NEIN, GEHE ZUR EINGABE DER 

ZIFFERNTASTE 

CMP # GOKEY ;JA, ISTTASTE "GO"? 

BEQ STTIM ;JA, STARTE ZEIT-ZÄHLUNG 

BNE WAITK ;NEIN, IGNORIERE TASTE 
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GIB ZIFFERNTASTE IN DIEANORDNUNG EIN, IGNORIERE DEZIMALPUNKT 
ODER "GO"-TASTE 


ENTDG CMP #10 
BCS WAITK 
INC NKEYS 

STA KEYNO,X 


ST TASTE EINE ZIFFER? 

NEIN, IGNORIERE SIE 
JA, INKREMENTIERE ANZAHL DER 
EINGEGEBENEN ZIFFERNTASTEN 
BEWAHRE ZIFFERNTASTE IN ANORDNUNG 
AUF 


;WARTE AUF ENDE DES MOMENTANEN TASTEN-SCHLIESSENS 

WAITK JSR SCANO .WARTE BIS ALLE TASTEN LOSGELASSEN 

; SIND 

BEO SRCHK ;HALTENACH NÄCHSTEM 

, TASTEN-SCHLIESSEN AUSSCHAU 
; (SCANO SETZT IMMERZ) 


VERARBEITEN DER ZIFFERN FÜR DIE ANZEIGE 


STTIM LDA KEYNO 
ORA #DECPT 

ORA #LEDON 
ORA #LEDSL 
STA KEYNO 
LDA KEYNO+1 
ORA #LEDON 
STA KEYNO+1 


;HOLE FÜHRENDE ZIFFERN 

;SCHALTE DEZIMALPUNKT FÜR FÜHRENDE 

; ZIFFER EIN 

;SETZE AUSGANGS-SIGNAL ZU DEN LEDS 
;WÄHLE FÜHRENDE ANZEIGE 

;HOLE FOLGENDE ZIFFER 

;SETZE AUSGANGSSIGNAL FÜR LEDS 


;PULSEN DER LED-ANZEIGE 

LEDLP LDA #6 ;SETZE ZÄHLER FÜR 1500 IMPULSE 

STA DCTR+1 

TLOOP LDA #250 

STA DCTR 

DSPLY LDA KEYNO ;SENDE FÜHRENDE ZIFFER ZU LED 1 

STA VIAORB 

LDY #TPULS ;VERZÖGERUNG ZWISCHEN ZIFFERN 

JSR DELAY 

LDA KEYNO+1 ;SENDE FOLGENDE ZIFFER ZUR LED 2 
STA VIAORB 

LDY #TPULS ;VERZÖGERUNG ZWISCHEN ZIFFERN 

JSR DELAY 

DEC DCTR 

BNE DSPLY 

DEC DCTR+1 

BNE TLOOP 
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;DEKREMENTIERE ZÄHLUNG AUF DEN LED ANZEIGEN 


LDA # LEDON 

DEC KEYNO+1 
BIT KEYNO+1 

BNE LEDLP 
DEC KEYNO 
BIT KEYNO 
BEO INITL 

LDA #9 
ORA #LEDON 
STA KEYNO+1 
BNE LEDLP 


HOLE BIT-MUSTER UND SCHAUE NACH 
ÜBERTRAG 

ZÄHLE FOLGENDE ZIFFER ABWÄRTS 
HAT DIE FOLGENDE ZIFFER NULL 
UNTERSCHRITTEN? 

NEIN. ZEIGE NEUE ZEIT AN 

JA, ZÄHLE FÜHRENDE ZIFFER ABWÄRTS 

IST FÜHRENDE ZIFFER UNTER NULL? 

JA, WARTE AUF NÄCHSTE 
ZEITGEBER-AUFGABE 
NEIN. MACHE FOLGENDE ZIFFER 9 
SETZE AUSGANGSSIGNAL ZU DEN LEDS 

KEHRE ZUM PULSEN DER ANZEIGEN 
ZURÜCK 


;DAS UNTERPROGRAMM SCANC TASTET DIE TASTATUR AB UND WARTET 
; AUF DAS SCHLIESSEN EINER TASTE 
; ALLE TASTATUR-EINGÄNGE LIEGEN AN MASSE 


SCANC 

LDA 

STA 

#0 

VIAORB 

;LEGE ALLE TASTATUR-SPALTEN AN 
; MASSE 

KEYCLS 

LDA 

VIAORA 

;HOLE TASTATURREIHEN-DATEN 


AND 

#OPEN 

JGNORIERE UNBENÜTZTE EINGÄNGE 


CMP 

#OPEN 

LIEGEN IRGENDWELCHE EINGÄNGE 
; AN MASSE? 


BEO 

RTS 

KEYCLS 

;NEIN, WARTE 


;DAS UNTERPROGRAMM DELAY WARTET AUF DIE ANZAHL DER MS. DIE IM 
; INDEX-REGISTER Y DURCH ZÄHLUNG MIT DEM INDEX-REGISTER X 
; SPEZIFIZIERT SIND 

DELAY LDX #MSCNT ;ZÄHLE FÜR EINE 1 MS-VERZÖGERUNG 

WTLP DEX .WARTE IMS 

BNE WTLP 

DEY ;ZÄHLE MS 

BNE DELAY 

RTS 


;DAS UNTERPROGRAMM IDKEY BESTIMMT DIE REIHEN- UND 
; SPALTENNUMMER DER GESCHLOSSENEN TASTE UND IDENTIFIZIERT DIE 
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FCOL 


LDA 

VIAORA 

AND 

#OPEN 

CMP 

#OPEN 

BNE 

FROW 

ROL 

VIAORB 

TXA 

ADC 

TAX 

# NROWS-1 

CMP 

#KLAST 

BNE 

FCOL 

LDA 

RTS 

#ECODE 


:HOLE TASTATURREIHEN-DATEN 
.IGNORIERE UNBENUTZTE EINGÄNGE 
;LIEGEN IRGENDWELCHE EINGÄNGE AN 
. MASSE? 

;JA, BESTIMME WELCHE REIHE AN MASSE 
; LIEGT 

;NEIN, VERSCHIEBE AUSGANG ZUM LEGEN 
; DER NÄCHSTEN SPALTE AN MASSE 
;BRINGE TASTENTABELLEN-ZEIGER ZUR 
; NÄCHSTEN SPALTE 


WURDEN ALLE SPALTEN GEPRÜFT? 
NEIN, PRÜFE NÄCHSTE SPALTE 
JA, KEHRE MIT FEHLERCODE IN A 
ZURÜCK 


BESTIMME REIHENNUMMER DER GESCHLOSSENEN TASTE 

FROW INX ;INKREMENTIERE TASTENT ABELLEN-INDEX 

LSR A ;SCHIEBE EINGÄNGE ZUR BESTIMMUNG 

; DER AN MASSE LIEGENDEN REIHE 

BCS FROW 

•IDENTIFIZIERE DIETASTEAUS DER TABELLE 

LDA KTAB.X HOLE TASTENNUMMER AUS TABELLE 

RTS 

TASTATUR-TABELLE 

•SPALTEN SIND DER PRIMÄRE INDEX, REIHEN DER SEKUNDÄRE INDEX. 

■DIE TASTEN IN DER SPALTE, OIE MIT AUSGANGSBIT 0 VERBUNDEN SIND, 
WERDEN VON JENEN IN DER SPALTE GEFOLGT, DIE ZUM AUSGANGSBIT 
’• 1 GEHÖREN, ETC. INNERHALB EINER SPALTE IST DIE MIT DEM 

• EINGANGSBIT OVERBUNDENETASTE DIE ERSTE, GEFOLGT VON DER MIT 
; EINGANGSBIT 1 VERBUNDENEN ETC. 


Projekt Nr. 2: Ein Digital-Thermometer 

Zweck: Dieses Projekt stellt ein Digital-Thermometer dar, das die Temperatur in 
Grad Celsius auf zwei Sieben Segment-Anzeigen darstellt. 

Hardware: Das Proiekt verwendet einen Eingangs- und einen Ausgangsport, 
zwei Sieben-Segment-Anzeigen, einen Inverter 74LS04, ein NANO-Gatter 
74LS00 oder ein UND-Gatter 74LS08, abhängig von der Polarität der Anzeigen, 
einen monolilischen A/D-Konverter mit 8 Bits AD7570J von Analog Devices, 
einen Komparator LM311 und verschiedene periphere Treiber, Widerstände und 
Kondensatoren, die von den Anzeigen und dem Konverter benötigt werden. 
(Siehe Kapitel 11 für eine Besprechung von A/D-Wandlern. Siehe auch Literatur 
1 am Ende dieses Kapitels für die Besprechung von A/D-Wandlern.) 

Bild 16-2 zeigt die Organisation der Hardware. Die Steuerleitung CB2 vom VIA 
wird zum Senden ernes Signals "Start der Umwandlung" zum A/D-Konverter 
verwendet Die Eingangsleitungen 0 bis 7 sind direkt mit acht digitalen Datenlei¬ 
tungen vom Konverter verbunden Die Ausgangsleitungen 0 bis 3 dienen zum 
Senden von BCD-Ziffern zu den Sieben-Segment-Decodern/Treibern. Die Aus¬ 
gangsleitung 4 aktiviert die Anzeigen, und die Ausgangsleitung 5 wählt die linke 
oder rechte Anzeige aus (Leitung 5 ist "1" für die linke Anzeige). Die Steuerlei¬ 
tung CA1 wird dazu verwendet, um zu bestimmen, wann die Umwandlung abge¬ 
schlossen ist (BUSY wird eins). 


Der Analogteil der Hardware ist in Bild 16-3 dar¬ 
gestellt. Der Thermistor bildet einfach einen Wi¬ 
derstand, der von der Temperatur abhängt Bild 
16-4 ist ein Diagramm des Widerstandes, und 
Bild 16-5 zeigt den Bereich des Stromes, bei dem der Widerstand konstant ist. 
Die Umwandlung in Grad Celsius im Programm wird mit einer Eichtabelle aus¬ 
geführt. Die verschiedenen Potentiometer können zum exakten Eichen der Da¬ 
ten verwendet werden. Ein Taktsignal für den A/D-Wandler wird von einem 
RC-Netzwerk erzeugt, wie in Bild 16-3 gezeigt ist. Die Werte sind R7 - 33kQ und 
C - 1000 pF, so daß die Taktfrequenz etwa bei 75 KHz liegt. Bei dieser Frequenz 
beträgt die maximale Umwandlungszeit für 8 Bits etwa 50 Mikrosekunden. Wenn 
BUSY auf High geht, setzt es Bit 1 des Unterbrechungsllag-Registers des VIA. 
Die 8-Bit-Versiondes Konverters benötigt folgende spezielle Verbindungen. Die 
acht Datenleitungen sind DB2 bis DB9 (DB1 ist immer High während der Um¬ 
wandlung und DBO Low). 


ANALOG¬ 
HARDWARE DES 
THERMOMETERS 


;D1E ZIFFERNTASTEN SIND 0 BIS 9. DER DEZIMALPUNKT IST 10 UNO "GO” 
; IST 11 

KTAB .BYTE 3,2,0,4,8.9,1,11,5,6,7.10 


DAS UNTERPROGRAMM SCANO WARTET, BIS ALLE TASTEN LOSGELASSEN 
, SIND. SO DASS DIE NÄCHSTE TASTENBELÄTIGUNG GEFUNDEN WERDEN 
KANN 


SCANO 

LDA 

#0 

;LEGE ALLE TASTATURSPALTEN AN MASSE 


STA 

VIAORB 


KEYOPN 

LDA 

VIAORA 

;HOLE TASTATURREIHEN-EINGÄNGE 

AND 

#OPEN 

;IGNORIERE UNBENUTZTE EINGÄNGE 


CMP 

#OPEN 

;SIND IRGENDWELCHE TASTEN 



; GEDRÜCKT? 


BNE 

KEYOPN 

;JA, WARTE BIS ALLE LOSGELASSEN 


RTS 




END 




Der 8-Bit-Eingang "Short Cycle" (Anschluß 26-SC8) wird auf Low gezogen, so 
daß im vorliegenden Fall nur eine 8-Bit-Umwandlung ausgeführt wird. Die An¬ 
schlüsse "High Byte Enable" (Anschluß 20-HBEN) und "Low Byte Enable" (An¬ 
schluß 21-LBEN) werden beide auf High gezogen, so daß die Daten-Ausgänge 
immer freigegeben sind. 

Der Wandler verwendet das Verfahren der Stufenumsetzung. Es vergleicht jedes 
Bit mit dem Ausgang eines D/A-Wandlers um festzustellen, ob dieses Bit ein- 
oder ausgeschaltet sein sollte. Jeder Vergleich benötigt eine Taktperiode. Die¬ 
ses Verfahren ist sehr schnell, jedoch fehleranfällig, wenn das Eingangssignal 
verrauscht ist. Genauere Methoden für die Handhabung analoger E/A sind in 
der Literatur am Ende des Kapitels beschrieben. 
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Bild 16-2. E/A-Konfiguration für ein Digital-Thermometer. 
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Bild 16-4. Kennlinie des Thermistors 
(Fenwal GA51J1 Bead). 



Bild 16-5. Typische E-I-Kennlinie (Orden Thermistor (25 °C) 


ifi.pn 


Allgemeines Flußdiagramm; 
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Programm-Beschreibung: 


5) Umwandlung der Daten in Grad Celsius 


1) Initialisierung 

Die Speicherplätze FFFC und FFFD (die Reset-Speicherplätze des 6502) 
enthalten die Start-Adresse des Programms. Die Initialisierung konfiguriert 
den VIA und plaziert einen Wer in den Stapelzeiger. Der Stapel wird nur zur 
Speicherung der Rückkehr-Adressen der Unterprogramme verwendet. Erin¬ 
nern Sie sich daran, daß Kapitel 12 zahlreiche Beispiele zur Konfiguration 
des VIA enthält. 

2) Senden des Startsignals zum A/D-Wandler für die Umwandlung 

Die CPU liefert das Startsignal für die Umwandlung, indem sie zuerst eine 
Eins und dann eine Null auf die Ausgangsleitung CB2 legt Jedes Eingangs¬ 
signal vom Wandler benötigt einen Start-Impuls. 

3) Warten auf den Abschluß der Umwandlung 

Ein Übergang von "0" auf "1” auf der BUSY-Leitung setzt Bit 1 des VIA- 
Unterbrechungsflag-Registers. In Wirklichkeit benötigt der Wandler nur ma¬ 
ximal 50 Mikrosekunden für eine 8-Bit-Umwandlung, so daß eine kurze Ver¬ 
zögerung ebenfalls ausreichend wäre. Beachten Sie, daß das Lesen der 
Wandler-Daten Bit 1 des VIA-Unterbrechungsflag-Registers löscht, so daß 
die nächste Operation ordnungsgemäß ablaufen kann. 

4) Lesen der Daten vom A/D-Wandler 

Das Lesen der Daten beinhaltet eine einzelne Eingabe-Operation. Wir soll¬ 
ten beachten, daß der Anatog-Baustein AD7570J einen Freigabe-Eingang 
und Tristale-Ausgänge besitzt, so daß er direkt mit dem Datenbus des Mi¬ 
kroprozessors verbunden werden könnte. 

Der Wandler 7570 wird natürlich in dieser speziellen Anwendung nicht voll 
genützt, insbesonders da wir ihn an einen 6502-Prozessor über ein VIA an¬ 
schließen. Ein einfacher 0-Bit-Wandler wie der im Kapitel 11 beschriebene 
5357 würde die Aufgabe billiger lösen. 


Flußdiagramm: 



Die Umwandlung verwendet eine Tabelle, die den 
größten Eingangswert entsprechend einer gege¬ 
benen Temperatur enthält. Das Programm sucht 
die Tabelle und hält nach einem Wert Ausschau, 
der größer oder gleich dem vom Konverter empfangenen Wert ist. Der erste der¬ 
art aufgefundene Wert entspricht der geforderten Temperatur, das heißt, wenn 
die zehnte Eingabe der erste Wert ist, der gleich oder größer als die 
Daten ist, beträgt die Temperatur 10 Grad. Dieses Suchverfahren ist nicht sehr 
effizient, reicht jedoch für die vorliegende Anwendung vollkommen aus. 


VERWENDUNG 

EINER 

EICH-TABELLE 


Das Umwandlungs-Unterprogramm gibt einen Binärwert zurück, der dann in 
BCD durch wiederholtes Subtrahieren von Zehn umgewandelt wird, bis der Rest 
negativ wird. Die letzte Zehn wird dann zurück addiert, um die niedrigstwertige 
Stelle zu bilden 

Die Tabelle könnte durch eine Eichung aufgestellt werden oder durch ein mathe¬ 
matisches Näherungsveifahren. Das Eichveriahren ist einfacher, da das Ther¬ 
mometer sonst auf andere Weise geeicht werden müßte. Die Tabelle belegt 
einen Speicherplatz für jeden Temperaturwert. Ein Verfahren, das wesentlich 
weniger Speicher verwendet, ist in den Literaturquellen 1 und 2 beschrieben. 

Um das Thermometer zu eichen, müssen Sie zuerst die Potentiometer einstel¬ 
len, damit der Gesamtbereich stimmt und dann die Ausgangswerte des Wand¬ 
lers für die entsprechende Temperatur bestimmen. 
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6) Vorbereitung der Daten für die Anzeige 


Flußdiagramm: 



Für die niedrigstwertige Stelle setzen wir eintach AUSBLENDEN 

das Bit, das die Anzeige einschaltet. Das Ergeb- EINER FÜHRENDEN 

nis wird im RAM-Speicherplatz LSTEMP auf- _ 

bewahrt. 

Der einzige Unterschied für die höchstwertige Stelle besteht darin, daß eine lüh- 
rende Null ausgeblendet wird (das heißt, die Anzeige zeigt "7" anstatt 07 für 
7 C) Dies beinhaltet einfach, daß das Bit nicht gesetzt wird, welches die Anzei¬ 
ge einschaltet, wenn die Stelle null ist Das Ergebnis wird in der Nullseiten- 
Adresse MSTEMP aufbewahrt. 
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7) Anzeige der Temperatur während der Dauer von sechs Sekunden 



Jede Anzeige wird häufig genug gepulst, so daß sie scheinbar ständig leuchtet. 
Wenn TPULS größer gemacht wird (beispielsweise 50 ms), würde die 
Anzeige flackern. 

Das Programm verwendet einen 16-Bit-Zähler in zwei Nullseiten-Speicherplät- 
zen für die Zählung der Zeit zwischen den Temperatur-Messungen. 
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NAME DES PROGRAMMS: THERMOMETER 
DATUM: 5/1/79 

PROGRAMMIERER: LANCE. A. LEVENTHAL 
PROGRAMM SPEICHER-ERFORDERNISSE: 173 BYTES 
BENÖTIGTES RAM: 5 BYTES 

E/A-ERFORDERNISSE: 1 EINGANGSPORT, 1 AUSGANGSPORT (1 VIA 6522} 


■DIESES PROGRAMM STELLTEIN DIGITALES THERMOMETER DAR. DAS 
EINGANGSSIGNALE VON EINEM A/D-WANDLER ANNIMMT, DER MIT 
EINEM THERMISTOR VERBUNDEN IST. ES WANDELT DAS 
EINGANGSSIGNAL IN GRAD CELSIUS UM UND ZEIGT DIE ERGEBNISSE 
AUF ZWEI SIEBEN-SEGMENT-LED-ANZEIGEN AN. 


.SCHRITT 4 - LESEN DES A/D-WANDLERS UND UMWANDLUNG IN GRAD 
CELSIUS 

FÜR DIE UMWANDLUNG WIRD EINE TABELLE VERWENDET, DIE DEN 
MAXIMALEN EINGANGSWERT FÜR JEDE TEMPERATUR-ABLESUNG 
ENTHÄLT. 

SCHRITT 5- ANZEIGE DER TEMPERATUR AUF DEN LEDS 
DIE TEMPERATUR WIRD AUF DEN LEDS SECHS SEKUNDEN LANG 
ANGEZEIGT. BEVOR EINE WEITERE UMWANDLUNG AUSGEFÜHRT WIRD. 


DEFINITIONEN DER VARIABLEN DES THERMOMETERS 


A/D-WANDLER 


SPEICHERSYSTEM-KONSTANTEN 


DER A/D-WANDLER IST EIN MONOLITHISCHER KONVERTER 7570J VON 
ANALOG DEVICES, DER EIN 0-BIT AUSGANGSSIGNAL LIEFERT 
DER UMWANDLUNGSVORGANG WIRD DURCH EINEN IMPULS AUF DER 
LEITUNG "START CONVERSION" (STEUERLEITUNG 2 AUF DEM 
VIA-PORT B GESTARTET 

DIE UMWANDLUNG WIRD INNERHALB VON 50 MIKROSEKUNDEN 
AUSGEFÜHRT, UND DIE DIGITALEN DATEN WERDEN 
ZWISCHENGESPEICHERT 

ANZEIGEN 

ES WERDEN ZWEI SIEBEN-SEGMENT-LED-ANZEIGEN MIT SEPARATEN 
DECODERN VERWENDET (7447 ODER 7448, ABHÄNGIG VON DERART 
DER ANZEIGE) 

DIE DATENEINGÄNGE DER DECODER SIND MIT DEN BITS 0 BIS 3 DES 
VIA PORTS B VERBUNDEN 

BIT 4 DES VIA-PORTS B WIRD ZUM AKTIVIEREN DER LED ANZEIGEN 
VERWENDET (BIT 4 IST 1 ZUM SENDEN VON DATEN ZU DEN LEDS) 

BIT 5 DES VIA-PORTS B DIENT ZUR AUSWAHL DER VERWENDETEN LED (BIT 
5 IST 1 WENN DIE FÜHRENDE ANZEIGE VERWENDET WIRD, 0, WENN DIE 
FOLGENDE ANZEIGE VERWENDET WIRD) 

VERFAHREN 

SCHRITT 1 - INITIALISIERUNG 

DER SPEICHERSTAPEL (VERWENDET FÜR RÜCKKEHR-ADRESSEN UND 
ANOERE SPEICHERZWECKE) WIRD INITIALISIERT 
SCHRITT 2 -PULSEN DER LEITUNG FÜR DEN START DER UMWANDLUNG 
DIE LEITUNG FÜR DEN START DER UMWANDLUNG DES A/D-WANDLERS 
WIRD GEPULST (STEUERLEITUNG 2 DES VIA-PORTS B) 

SCHRITT 3-WARTEN AUF STABILEN ZUSTAND DES 
A/D-AUSGANGSSIGNALS 

DIE LEITUNG "BUSY" VOM WANDLER WIRD MIT DER STEUERLEITUNG 1 
: AM PORT A DES VIA VERBUNDEN. WENN "BUSY" AUF HIGH GEHT UM ZU 
SIGNALISIEREN, DASS DIE SIGNAL-UMWANDLUNG ABGESCHLOSSEN IST, 
SETZT SIE BIT 7 DES VIA-UNTERBRECHUNGSFLAG-REGISTERS. 


BEGIN -$0400 
STKBGN -$FF 

TEMP -0 


;START-ADRESSE FÜR DAS PROGRAMM 
;STARTADRESSE FÜR DEN STAPEL AUF 
SEITEI 

;STARTADRESSE FÜR DEN RAM-SPEICHER 


;E/A-EINHEITEN UND VIA-ADRESSEN 


VIAORB -$A000 
VIAORA -SA001 
VIADDRB -SA002 
VIADDRA -SA003 

VIAPCR -$A00C 
VIAFIR “$A00D 


AUSGANGSPORT FÜR ANZEIGEN 
EINGANGSPORT FÜR WANDLER 
DATEN-RICHTUNGS-REGISTER FÜR PORT B 
DATEN-RICHTUNGS-REGISTER FÜR 
PORTA 

PERIPHERES STEUERREGISTER DES VIA 
UNTERBRECHUNGSFLAG REGISTER DES 
VIA 


ZEITWEILIGER RAM-SPEICHER 


'-TEMP 


DCTRC 

*-*+2 

INPUT 

'_'+1 

LSTEMP 

*-*+1 

MSTEMP 

*-*+1 


;DEFINITIONEN 


BUSYF 

-%00000010 

LEDON 

-AfeOOOl 0000 

LEDSL 

-%00100000 

MSCNT 

-$C7 

TSAMPH 

-6 


ANZEIGEIMPULS-ZÄHLER 
ZWISCHENSPEICHER FÜR 
; WANDLER-EINGANG 
NIEDRIGSTWERTIGESTELLE DER 
TEMPERATUR 

;HÖCHSTWERTIGE STELLE DER 
TEMPERATUR 


;MUSTER ZUM PRÜFEN DES BUSY-STATUS 
;CODE ZUM SENDEN DES AUSGANGS- 
; SIGNALS ZU DEN LEDS 
;CODE ZUR AUSWAHL DER FÜHRENDEN 
; ANZEIGE 

ERFORDERLICHEZÄHLUNG FÜR 1 MS 
; VERZÖGERUNGSZEIT 
iTSAMPL GIBT AN, WIE OFT DIE ANZEIGEN 
; IN EINER ABTAST-PERIODE DER 
; TEMPERATUR GEPULST WERDEN. 
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TSAMPL =250 


TPULS =2 

*.»$FFFC 

;RESET ADRESSE DES THERMOMETER PROGRAMMS 
WORD BEGIN 

^INITIALISIERUNG DES THERMOMETER-PROGRAMMS 
*=BEGIN 



LDX 

#STKBGN 

INITIALISIERE STAPELZEIGER 


TXS 




LDA 

#0 

;MACHE PORT-A-LEITUNGEN ZU 



; EINGÄNGEN 


STA 

VIADDRA 



LDA 

#$FF 

;MACHE PORT-B-LEITUNGEN ZU 




; AUSGÄNGEN 


STA 

VIADDRB 



LDA 

#%1 1 000001 

;MACHE "START CONVERSION" LOW, 




; BUSY-AKTIV-LOW AUF HIGH 


STA 

VIAPCR 

KONFIGURIERE PERIPHERE STEUERUNG 




; DES VIA 


LDA 

# BUSYF 

;LÖSCHE BUSY-FLAG 


STA 

VIAIFR 


■PULSE LEITUNG 

FÜR DEN START DER UMWANDLUNG 

START 

LDA 

# % 11100001 

;SENDE START-UMWANDLUNG HIGH 


STA 

VIAPCR 



LDA 

#%11000001 

;SENDE START-UMWANDLUNG LOW 


STA 

VIAPCR 


■WARTE, BIS BUSY AUF HIGH GEHT UND LIES DATEN 

' 

LDA 

#BUSYF 


WTBSY 

BIT 

VIAFR 

;IST UMWANDLUNG ABGESCHLOSSEN? 


BEO 

WTBSY 

iNEIN, WARTE 


LDA 

VIAORA 

;JA, LIES DATEN VOM WANDLER 


KONFIGURIERE ZIFFERN FÜR ANZEIGE 



ORA 

#LEDON 

iSETZE AUSGANG ZU LEDS(LSD IN A) 


STA 

LSTEMP 

;BEWAHRE NIEDRIGSTWERTIGE STELLE 




; AUF 


TXA 


,HOLE HÖCHSTWERTIGE ZIFFER 


BEQ 

SVMSD 

LASSE ANZEIGE AUSGESCHALTET, WENN 




; MSD NULL IST 


ORA 

#LEDON 

SETZE AUSGANG ZU LEDS 


ORA 

#LEDSL 

;WÄHLE FÜHRENDE ANZEIGE AUS 

SVMSD 

STA 

MSTEMP 

;BEWAHRE HÖCHSTWERTIGE STELLE AUF 

iPULSE 

DIE LED-ANZEIGEN 


PULSE 

LDA 

#TSAMPH 

,16-BIT-ZÄHLER FÜR ANZEIGE-IMPULSE 


STA 

DCTR+1 


TLOOP 

LDA 

#TSAMPL 



STA 

DCTR 


DSPLY 

LDA 

MSTEMP 

.AUSGABE ZU FÜHRENDER ANZEIGE 


STA 

VIAORB 



LDY 

#TPULS 

.VERZÖGERE ANZEIGE IMPULSLÄNGE 


JSR 

DELAY 



LDA 

LSTEMP 

.AUSGABE ZU FOLGENDER ANZEIGE 


STA 

VIAORB 



LDY 

#TPULS 

VERZÖGERE ANZEIGE-IMPULSLÄNGE 


JSR 

DELAY 



DEC 

DCTR 



BNE 

DSPLY 



DEC 

DCTR+1 

;HAT DIE ZÄHLUNG NULL ERREICHT -7 


BNE 

TLOOP 

;NEIN, SETZE PULSEN DER ANZEIGE FORT 


BEO 

START 

;JA, HOLE NEUEN TEMPERATURWERT 


UNTERPROGRAMM DELAY WARTET AUF DIE ANZAHL DER IM 
INDEX REGISTER Y DURCH ZÄHLUNG MIT DEM INDEX-REGISTER X 
SPEZIFIZIERTEN MS 


DELAY LDX 

# MSCNT 

;ZÄHLE FÜR 1 MS-VERZÖGERUNG 

WTLP DEX 


;WARTE 1 MS 

BNE 

WTLP 


DEY 



BNE 

DELAY 

;ZÄHLE ANZAHL DER MS 

RTS 




UNTERPROGRAMM CONVR WANDELT EINGANGSSIGNAL VOM 
A/D-WANDLER IN GRAD CELSIUS DURCH VERWENDUNG EINER TABELLE 
UM. EINGANGSDATEN LIEGEN IM AKKUMULATOR UND ERGEBNIS IST 
EINE BINÄRZIFFER IM AKKUMULATOR 


DIE LÄNGE EINER ABTASTPERIODE IST 
DAHER 2'TPULS*TSAMPH*TSAMPL- 
MILLISEKUNDEN.DER FAKTOR VON 
2*TPULS WIRD DURCH DIE TATSACHE 
BEDINGT, DASS JEDE DER ZWEI 
ANZEIGEN TPULS MS LANG GEPULST 
WIRD. 

ANZEIGE FÜR PULS-LÄNGE IN MS 


;WANDLE DATEN FÜR TEMPERATUR IN DEZIMAL UM 

JSR CONVR ;WANDLE DATEN FÜR TEMPERATUR IN 

; BINÄR UM 

JSR BINBCD ;WANDLE BINÄR IN BCD UM 
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VERWENDETE REGISTER: A,X 
VERWENDETER SPEICHERPLATZ: EINGANG 


LITERATUR 


CONVR 

STA 

INPUT 

BEWAHRE GELESENES EINGANGSSIGNAL 
AUF 


LDX 

#$FF 

STARTE TABELLEN-INDEX BEI-1 

CHVAL 

INX 


INKREMENTIERETABELLEN-INDEX 


LDA 

DEGTB,X 

HOLE EINGABE VON TABELLE 


CMP 

INPUT 

IST A/D-EINGANG UNTER EINGABE? 


BCC 

TXA 

RTS 

CHVAL 

NEIN, HALTE WEITER AUSSCHAU 

JA, KEHRE MIT T IN AKKUMULATOR 
ZURÜCK 


TABELLE DEGTB WÜRDE DURCH EICHUNG GEFUNDEN. 

DEGTB ENTHÄLT DIE GRÖSSTEN EINGANGSWERTE, DIE EINER SPEZIELLEN 
TEMPERATUR-ABLESUNG ENTSPRECHEN (D.H., DIE ERSTE EINGABE IST 
DEZIMAL 58. SO DASS EIN EINGANGSWERT VON 50 DER GRÖSSTE WERT 
IST, DER EINE TEMPERATUR-ABLESUNG VON NULL ERGIBT- WERTE 
UNTER NULL SIND NICHT GESTATTET) 


1. E. R. Hnatek, A User s Handbook ol D/A and A/D Converters, Wiley New 
York, 1976. 

2. T. A. Seim, "Numerical Inlerpolation tor Microprocessor-Based Systems." 
Computer Design, February 1978, pp. 11 1-1 16. 

3. D. H. Shelngold, ed.. Analog -Digital Conversion Notes, Analog Devices, 
Inc., P. O. Box 796, Norwood, MA. 02062, 1977. 

4. D. P. Builon, and A. L. Dexter, Microprocessor Systems Handbook, Analog 
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6 F. Molinari, et al„ "Shopping for the Right Analog I/O Board", Electronic 
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DEGTB BYTE 
BYTE 
BYTE 
BYTE 
.BYTE 
BYTE 
BYTE 


58,61,63,66,69,71,74,77,00,84 
07,90,93,97,101,104,108 

112.1 16,120,124,128,132,136 
141,145,149.154.158,163,167 

172.177.181.186.191.1 95,200 
204,209,214,218,223,227,232 
236,241,245,249.253,255 


7. Ausländer, D. M. et al„ "Direct Digital Process Control: Practice and Algo- 
rithms for Microprocessor Applications". Proceedings of the IEEE, Februa 
ry 1978, pp. 199-200. 

8. R J. Bibbero. Microprocessors in Instruments and Control, Wiley New 
York, 1 977 


DAS UNTERPROGRAMM BINBCD WANDELT EINE BINÄRZAHL KLEINER ALS 
100 IN ZWEI BCD-ZIFFERN UM. DIE EINGANGSDATEN LIEGEN IM 
AKKUMULATOR, UND DIE ERGEBNISSE LIEGEN IM INDEX REGISTER X 
(HÖCHSTWERTIGE STELLE) UND IM AKKUMULATOR (NIEDRIGSTWERTIGE 
STELLE) 


VERWENDETE REGISTER: A,X 


BINBCD 

LDX 

SEC 

#$FF 

ZEHNER-ZÄHLUNG --1 

SETZE ÜBERTRAG ZU ANFANG 

SUBTEN 

INX 


INKREMENTIERE ZEHNER-ZÄHLUNG 


SBC 

#10 

KANN ZEHN NOCH SUBTRAHIERT 
WERDEN? 


BCS 

SUBTEN 

JA, SETZE PORT 


ADC 

RTS 

.END 

#10 

NEIN, ADDIERE LETZTE ZEHN ZURÜCK 


9. A. Mrozowski. Analog Output Chips Shrink A-D Conversion Software”. 
Electronics, June 23.1977, pp. 130-133. 

10. P. R Rony et al, "Microcomputer Interfacing: Sample and Hold Devices" 
Computer Desion . December 1977, pp 106-108. 

11. P. H. Garrett, An alog Sy stems for Microprocessors and Minicomputers 
Reston Publishing Co., Reston, VA., 1978. 

12. The Op toelectronics Data Book, Texas Instruments, Inc., P O Box 5012 
Dallas, TX, 1970. 

12. The Optoelectronic Designers Catalog, Hewlett-Packard, Inc., 1820 
Embarcadero Road. Palo Alto, CA 94303, 1978. 
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